字符串轮转。给定两个字符串s1和s2,请编写代码检查s2是否为s1旋转而成(比如,waterbottle是erbottlewat旋转后的字符串)。
示例1:
输入:s1 = “waterbottle”, s2 = “erbottlewat”
输出:True
示例2:
输入:s1 = “aa”, s2 = “aba”
输出:False
提示:
字符串长度在[0, 100000]范围内。
说明:
你能只调用一次检查子串的方法吗?
方法一:
暴力对比。
- 首先特判一下,s1,s2长度为0,return true; 否则:s1,s2任意一个为“” return false; 还有:s1,s2长度不等,return false;
- 在s2中找到所有s1开头字符的下标,然后进行循环判断,有任意一个与s1匹配了,return true。否则return false;
代码:
class Solution {
public boolean isFlipedString(String s1, String s2) {
// 暴力循环对比。
if (s1.length() == 0 && s2.length() == 0) return true;
if (s1.length() != s2.length() || s1.length() == 0 || s2.length() == 0) return false;
char[] arr1 = s1.toCharArray();
char[] arr2 = s2.toCharArray();
ArrayList<Integer> idxs = findIdx(arr1, arr2);
for (int i : idxs)
if (judge(arr1, arr2, i))
return true;
return false;
}
private ArrayList findIdx(char[] arr1, char[] arr2) {
char c = arr1[0];
ArrayList<Integer> idxs = new ArrayList<>();
for (int i = 0; i < arr1.length; i++) {
if (arr2[i] == c) idxs.add(i);
}
return idxs;
}
private boolean judge(char[] arr1, char[] arr2, int start) {
int idx = 0;
for (int i = start; idx < arr1.length; i++) {
if (arr1[idx] != arr2[(i % arr1.length)]) return false;
idx ++;
}
return true;
}
}
时间复杂度:O(n + kn) 循环s2字符串寻找所有s1字符串首字符下标,并且,每个下标都要循环判断一遍s2字符串是否和s1匹配。
空间复杂度:O(m + n + k) m,n是两个字符串长度,k是s1字符串第一个字符重复的次数。
更好的解法待续…