Leetcode459:重复的字符串

解题思路:

如果您的字符串 S 包含一个重复的子字符串,那么这意味着您可以多次 "移位和换行"`您的字符串,并使其与原始字符串匹配。

例如:abcabc

移位一次:cabcab

移位两次:bcabca

移位三次:abcabc

现在字符串和原字符串匹配了,所以可以得出结论存在重复的子串。

基于这个思想,可以每次移动k个字符,直到匹配移动 length - 1 次。但是这样对于重复字符串很长的字符串,效率会非常低。在 LeetCode 中执行时间超时了。

为了避免这种无用的环绕,可以创建一个新的字符串 str,它等于原来的字符串 S 再加上 S 自身,这样其实就包含了所有移动的字符串。

比如字符串:S = acd,那么 str = S + S = acdacd

acd 移动的可能:dac、cda。其实都包含在了 str 中了。就像一个滑动窗口

一开始 acd (acd) ,移动一次 ac(dac)d,移动两次 a(cda)cd。循环结束

所以可以直接判断 str 中去除首尾元素之后,是否包含自身元素。如果包含。则表明存在重复子串。

复制代码
class Solution {
    public boolean repeatedSubstringPattern(String s) {
        String str=s+s;
        return str.substring(1,str.length()-1).contains(s);
    }
}
相关推荐
C雨后彩虹1 分钟前
斗地主之顺子
java·数据结构·算法·华为·面试
CC.GG9 分钟前
【C++】AVL树
java·开发语言·c++
闲人编程9 分钟前
基础设施即代码(IaC)工具比较:Pulumi vs Terraform
java·数据库·terraform·iac·codecapsule·pulumi
墨上烟雨13 分钟前
Pandas 数据结构 - Series
数据结构·pandas
鸽鸽程序猿14 分钟前
【刷题册】二
算法
QQ_216962909616 分钟前
Spring Boot大学生社团管理平台 【部署教程+可完整运行源码+数据库】
java·数据库·spring boot·微信小程序
Ahtacca20 分钟前
Maven 入门:项目管理与依赖管理的核心玩法
java·maven
CoderCodingNo23 分钟前
【GESP】C++四级真题 luogu-B4416 [GESP202509 四级] 最长连续段
开发语言·c++·算法
xjxijd23 分钟前
工业元宇宙 IDC 支撑:数字孪生算法 + 边缘服务器,生产调度响应速度提 3 倍
运维·服务器·算法
a程序小傲26 分钟前
京东Java面试被问:Fork/Join框架的使用场景
java·开发语言·后端·postgresql·面试·职场和发展