原文链接: https://leetcode-cn.com/problems/repeated-substring-pattern
英文原文
Given a string s
, check if it can be constructed by taking a substring of it and appending multiple copies of the substring together.
Example 1:
Input: s = "abab" Output: true Explanation: It is the substring "ab" twice.
Example 2:
Input: s = "aba" Output: false
Example 3:
Input: s = "abcabcabcabc" Output: true Explanation: It is the substring "abc" four times or the substring "abcabc" twice.
Constraints:
1 <= s.length <= 104
s
consists of lowercase English letters.
中文题目
给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。
示例 1:
输入: "abab" 输出: True 解释: 可由子字符串 "ab" 重复两次构成。
示例 2:
输入: "aba" 输出: False
示例 3:
输入: "abcabcabcabc" 输出: True 解释: 可由子字符串 "abc" 重复四次构成。 (或者子字符串 "abcabc" 重复两次构成。)
通过代码
高赞题解
解题思路
如果您的字符串 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);
}
}
暴力代码如下:
//暴力代码
public boolean repeatedSubstringPattern(String s) {
for(int i = 1; i < s.length(); i++) {
String str = rotate(s.toCharArray(),i);
if(s.equals(str)) return true;
}
return false;
}
public String rotate(char[] nums, int k) {
k = k % nums.length;
reverse(nums, 0, nums.length - 1);
reverse(nums, 0, k - 1);
reverse(nums, k, nums.length - 1);
return String.valueOf(nums);
}
public void reverse(char[] nums, int begin, int end) {
int i = begin, j = end;
while(i < j) {
char temp = nums[i];
nums[i++] = nums[j];
nums[j--] = temp;
}
}
统计信息
通过次数 | 提交次数 | AC比率 |
---|---|---|
84928 | 166594 | 51.0% |
提交历史
提交时间 | 提交结果 | 执行时间 | 内存消耗 | 语言 |
---|
相似题目
题目 | 难度 |
---|---|
实现 strStr() | 简单 |
重复叠加字符串匹配 | 中等 |