给定一个非空的字符串,检查是否可以通过由它的一个子串重复多次构成。
class Solution {
public:
//构造next数组(前缀表减1)
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;
}
}
//注:最长相等前后缀的长度为:next[len - 1] + 1
bool repeatedSubstringPattern (string s) {
//当字符串长度为0时,返回false
if (s.size() == 0) {
return false;
}
int next[s.size()];
getNext(next, s);
int len = s.size();
//(len - (next[len - 1] + 1)) 也就是: 字符串的长度 - 最长公共前后缀的长度 = x, x正好可以被 (字符串的长度) 整除,所以说明有重复的子字符串
if (next[len - 1] != -1 && len % (len - (next[len - 1] + 1)) == 0) {
return true;
}
return false;
}
};
1131

被折叠的 条评论
为什么被折叠?



