力扣题目链接(opens new window)

给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。

示例 1:
输入: "abab"
输出: True
解释: 可由子字符串 "ab" 重复两次构成。

示例 2:
输入: "aba"
输出: False

示例 3:
输入: "abcabcabcabc"
输出: True
解释: 可由子字符串 "abc" 重复四次构成。 (或者子字符串 "abcabc" 重复两次构成。)

一、思路

这又是一道标准的KMP的题目。

如果KMP还不够了解,可以看我的B站:

  • 帮你把KMP算法学个通透!(理论篇)(opens new window)
  • 帮你把KMP算法学个通透!(求next数组代码篇)(opens new window)

我们在字符串:KMP算法精讲 (opens new window)里提到了,在一个串中查找是否出现过另一个串,这是KMP的看家本领。

那么寻找重复子串怎么也涉及到KMP算法了呢?

这里就要说一说next数组了,next 数组记录的就是最长相同前后缀( 字符串:KMP算法精讲 (opens new window)这里介绍了什么是前缀,什么是后缀,什么又是最长相同前后缀), 如果 next[len - 1] != -1,则说明字符串有最长相同的前后缀(就是字符串里的前缀子串和后缀子串相同的最长长度)。

最长相等前后缀的长度为:next[len - 1] + 1。数组长度为:len。如果len % (len - (next[len - 1] + 1)) == 0 ,则说明 (数组长度-最长相等前后缀的长度) 正好可以被 数组的长度整除,说明有该字符串有重复的子字符串。

数组长度减去最长相同前后缀的长度相当于是第一个周期的长度,也就是一个周期的长度,如果这个周期可以被整除,就说明整个数组就是这个周期的循环。强烈建议大家把next数组打印出来,看看next数组里的规律,有助于理解KMP算法

如图:

next[len - 1] = 7,next[len - 1] + 1 = 8,8就是此时字符串asdfasdfasdf的最长相同前后缀的长度。

(len - (next[len - 1] + 1)) 也就是: 12(字符串的长度) - 8(最长公共前后缀的长度) = 4, 4正好可以被 12(字符串的长度) 整除,所以说明有重复的子字符串(asdf)。

C++代码如下:(这里使用了前缀表统一减一的实现方式)

class Solution {
public:void getNext (int* next, const string& s){next[0] = -1;int j = -1;for(int i = 1;i < s.size(); i++){while(j >= 0 && s[i] != s[j+1]) {j = next[j];}if(s[i] == s[j+1]) {j++;}next[i] = j;}}bool repeatedSubstringPattern (string s) {if (s.size() == 0) {return false;}int next[s.size()];getNext(next, s);int len = s.size();if (next[len - 1] != -1 && len % (len - (next[len - 1] + 1)) == 0) {return true;}return false;}
};

前缀表(不减一)的C++代码实现

class Solution {
public:void getNext (int* next, const string& s){next[0] = 0;int j = 0;for(int i = 1;i < s.size(); i++){while(j > 0 && s[i] != s[j]) {j = next[j - 1];}if(s[i] == s[j]) {j++;}next[i] = j;}}bool repeatedSubstringPattern (string s) {if (s.size() == 0) {return false;}int next[s.size()];getNext(next, s);int len = s.size();if (next[len - 1] != 0 && len % (len - (next[len - 1] )) == 0) {return true;}return false;}
};

二、拓展

在字符串:KMP算法精讲 (opens new window)中讲解KMP算法的基础理论,给出next数组究竟是如何来了,前缀表又是怎么回事,为什么要选择前缀表。

讲解一道KMP的经典题目,力扣:28. 实现 strStr(),判断文本串里是否出现过模式串,这里涉及到构造next数组的代码实现,以及使用next数组完成模式串与文本串的匹配过程。

后来很多同学反馈说:搞不懂前后缀,什么又是最长相同前后缀(最长公共前后缀我认为这个用词不准确),以及为什么前缀表要统一减一(右移)呢,不减一行不行?针对这些问题,我在字符串:KMP算法精讲 (opens new window)给出了详细的讲解。

四、字符串(7):重复的子字符串相关推荐

  1. 字符串7——重复的子字符串

    字符串7--重复的子字符串 例题 题目链接 题目说明 解题 方法一:枚举 思路与算法 代码 复杂度分析 方法二:字符串匹配 思路与算法 代码 复杂度分析 方法三:KMP 算法 思路与算法 代码 复杂度 ...

  2. js实现kmp算法_「leetcode」459.重复的子字符串:KMP算法还能干这个!

    不瞒你说,重复子串问题,KMP很拿手 题目459.重复的子字符串 给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: ...

  3. 算法Day8|字符串专题二 剑指 Offer 58 - II. 左旋转字符串,28. 找出字符串中第一个匹配项的下标,459. 重复的子字符串

    剑指 Offer 58 - II. 左旋转字符串 解题思路: 反转区间为前n的子串 反转区间为n到末尾的子串 反转整个字符串 class Solution {public String reverse ...

  4. 【字符串】leet459.重复的子字符串(C/C++/Java/Python/Js)

    leetcode459.重复的子字符串 1 题目 2 思路 3 代码 3.1 C++版本 3.2 C版本 3.3 Java版本 3.4 Python版本 3.5 JavaScript版本 4 总结 K ...

  5. 力扣459. 重复的子字符串(KMP,JavaScript)

    如果 next[len - 1] != 0,则说明字符串有最长相同的前后缀(就是字符串里的前缀子串和后缀子串相同的最长长度). 最长相等前后缀的长度为:next[len - 1] . 数组长度为:le ...

  6. qt判断读入的字符串是否含有英文_459. 重复的子字符串

    给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000.示例 1:输入: "abab"输出: True解释: 可由 ...

  7. 字符串删除首尾_[LeetCode] 459. 重复的子字符串

    题目链接: https://leetcode-cn.com/problems/repeated-substring-pattern 难度:简单 通过率:42.6% 题目描述: 给定一个非空的字符串,判 ...

  8. 459. Repeated Substring Pattern 重复的子字符串

    给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab"输出: True解释: ...

  9. LeetCode 459. 重复的子字符串(数学)

    1. 题目 给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000. 示例 1: 输入: "abab" 输出: T ...

  10. qt判断读入的字符串是否含有英文_重复的子字符串

    给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成.给定的字符串只含有小写英文字母,并且长度不超过10000.示例 1:输入: "abab"输出: True解释: 可由 ...

最新文章

  1. 【AI初识境】给深度学习新手做项目的10个建议
  2. Josephus 问题相关
  3. orion算法被解密了
  4. SE37 test sequence - 在同一个main session内依次执行function module
  5. 三星笔记本进入BIOS后找不到U盘启动项/快速启动键F12没有反应
  6. Error running tomcat8 Address localhost:1099 is already in use 错误解决
  7. 在ASP.NET 3.5中使用新的ListView控件(4)
  8. 腾讯否认“PC端QQ秀下线”:只是在聊天窗口被折叠
  9. SVN快速入门3——整合eclipse(1)
  10. DiscuzNT改造-远程图片自动采集-DNT2.5(自动采集、源码下载)
  11. python解决sip与ptqt不兼容导致页面截图引擎无法运行问题
  12. Anylogic-----------集合Collection
  13. matlab 矩阵逻辑与,MATLAB矩阵的寻访与赋值
  14. 【测试理论】如何做好探索性测试(二)—增加维度
  15. JS计算时间差;.net计算时间差
  16. welearn考试切屏会有显示吗_welearn答案在哪里可以看?公众号、app或者微信小程序?...
  17. IDA反汇编工具使用详解
  18. 猫、路由器和交换机的区别和联系
  19. 团队管理那点破事,OKR绩效、核心人才、面试、技术分享、研发流程
  20. idea回到上一个光标位置

热门文章

  1. Servlet-JSP-课堂笔记
  2. 吐血推荐:数据库你想知道的都在这
  3. [OpenAirInterface实战-16] :OAI 软件无线电USRP X300/X310硬件详解
  4. 纪一次笔试之行—燃烧的远征
  5. AngularJS $destroy
  6. 为什么中国没有CES ? | 云栖大会科技榜单
  7. 用计算机求算术平方根,6.1用计算机计算算术平方根.ppt
  8. 搭建WinDbg应用程序调试环境
  9. 《犹太人想的和你不一样》
  10. NUVOTON的IAP SFR