解题思路:滑动窗口。
异位词的典型解题方法就是用数组来统计出现的个数。本题也不例外。
直接上代码来进行讲解:
public List<Integer> findAnagrams(String s, String p) {
//初始化返回数组
List<Integer> res = new ArrayList<>();
if (p.length()>s.length()){
return res;
}
int arr[] = new int[26];
int cur[] = new int[26];
//统计s中的字符出现个数,这里需要注意的是i的范围
for (int i = 0; i < p.length()-1; i++) {
cur[s.charAt(i) - 'a']++;
}
//统计p中出现的字符个数
for (int i = 0; i < p.length(); i++) {
arr[p.charAt(i) - 'a']++;
}
//定义左右指针,每次循环左右指针进行向右移动
for (int left = 0, right = p.length()-1; right < s.length(); left++, right++) {
cur[s.charAt(right) - 'a']++;
if (Arrays.equals(cur, arr)) {
res.add(left);
}
cur[s.charAt(left) - 'a']--;
}
return res;
}
可能有同学对这里的代码不是太理解是干嘛的,我们来举个例子就好理解了。
假如我们的测试用例是下面的:
String s = "cbaebabacd";String p = "abc";
我们经过两个for循环之后,也就是统计字符出现的次数。
arr
和cur
分别是下面的结果:
cur中统计的是cb两个字符,进入下面的for循环第一步就是把right所指的地方的a字符假加入到cur数组中,然后进行比较,比较后,再把c字符删去。每次循环的时候cur都是两个字符,然后加入一个字符判断,判断完毕之后再删除一个字符。
如果觉得还不是很理解,建议debug下自己尝试下,本题需要注意的点就是cur数组统计字符的时候最开始是统计两个。然后就是上面的每次cur数组中的加入字符和减去字符的代码,需要理解清楚。