博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode] Repeated Substring Pattern 重复子字符串模式
阅读量:7202 次
发布时间:2019-06-29

本文共 1988 字,大约阅读时间需要 6 分钟。

 

Given a non-empty string check if it can be constructed by taking a substring of it and appending multiple copies of the substring together. You may assume the given string consists of lowercase English letters only and its length will not exceed 10000.

Example 1:

Input: "abab"Output: TrueExplanation: It's the substring "ab" twice.

 

Example 2:

Input: "aba"Output: False

 

Example 3:

Input: "abcabcabcabc"Output: TrueExplanation: It's the substring "abc" four times. (And the substring "abcabc" twice.)

 

这道题给了我们一个字符串,问其是否能拆成n个重复的子串。那么既然能拆分成多个子串,那么每个子串的长度肯定不能大于原字符串长度的一半,那么我们可以从原字符串长度的一半遍历到1,如果当前长度能被总长度整除,说明可以分成若干个子字符串,我们将这些子字符串拼接起来看跟原字符串是否相等。 如果拆完了都不相等,返回false。

 

解法一:

class Solution {public:    bool repeatedSubstringPattern(string str) {        int n = str.size();        for (int i = n / 2; i >= 1; --i) {            if (n % i == 0) {                int c = n / i;                string t = "";                for (int j = 0; j < c; ++j) {                    t += str.substr(0, i);                 }                if (t == str) return true;            }        }        return false;    }};

 

下面这种方法是参考的,原作者说是用的KMP算法,LeetCode之前也有一道应用KMP算法来解的题,但是感觉那道题才是KMP算法。这道题也称为KMP算法感觉怪怪的(关于KMP的详细介绍请参见,也可以看博主自己写的一篇),KMP算法中的next数组是找当前位置的最大相同前缀后缀的个数,而这道题维护的一位数组dp[i]表示,到位置i-1为止的重复字符串的字符个数,不包括被重复的那个字符串,什么意思呢,我们举个例子,比如"abcabc"的dp数组为[0 0 0 0 1 2 3],dp数组长度要比原字符串长度多一个。那么我们看最后一个位置数字为3,就表示重复的字符串的字符数有3个。如果是"abcabcabc",那么dp数组为[0 0 0 0 1 2 3 4 5 6],我们发现最后一个数字为6,那么表示重复的字符串为“abcabc”,有6个字符。那么怎么通过最后一个数字来知道原字符串是否由重复的子字符串组成的呢,首先当然是最后一个数字不能为0,而且还要满足dp[n] % (n - dp[n]) == 0才行,因为n - dp[n]是一个子字符串的长度,那么重复字符串的长度和肯定是一个子字符串的整数倍,参见代码如下:

 

解法二:

class Solution {public:    bool repeatedSubstringPattern(string str) {        int i = 1, j = 0, n = str.size();        vector
dp(n + 1, 0); while (i < n) { if (str[i] == str[j]) dp[++i] = ++j; else if (j == 0) ++i; else j = dp[j]; } return dp[n] && (dp[n] % (n - dp[n]) == 0); }};

 

类似题目:

 

参考资料:

 

转载地址:http://xgwum.baihongyu.com/

你可能感兴趣的文章
View requires API level 14 (current min is 8)
查看>>
flannel集群安装
查看>>
android 的viewpager如何实现左右循环
查看>>
易宝典文章——玩转Office 365中的Exchange Online服务 之二十三 实现基于IP地址的邮件过滤...
查看>>
Anychat即时通讯系统
查看>>
2011年 小结
查看>>
手机网站的网页进行微信转发时遇到的问题
查看>>
在RHEL6上配置基于ftp的YUM
查看>>
【行为型】- 状态模式
查看>>
AIX5.3 hacmp配置
查看>>
Linux关闭休眠和屏保模式
查看>>
我的友情链接
查看>>
笨笨的我---终于完成了vim下php IDE的配置
查看>>
php---window 7 配置memcached并测试成功
查看>>
用MyEclipse做Junit测试时报错
查看>>
sed批量替换文件内容
查看>>
linux基础命令学习之mkdir(3)
查看>>
ELK体系大型日志分析集群方案设计.搭建.调优.管理
查看>>
cacti监控工具之自定数据收集方法
查看>>
面试感悟----一名3年工作经验的程序员应该具备的技能
查看>>