leetcode 438.找到字符串中所有字母异位词

思路:其实就是用滑动窗口的思想,想象出来一个定长的窗口,在原字符串上进行移动,然后判断这个里面的字母是不是和所给字母全部一样。这个实现可以用循环然后用String的substring来模拟滑动窗口。

还有一个问题在于我们怎么判断窗口里面的字母和参照组的字符串里面的字母就是一样的呢?

有一个惯常的方法,就是把所给匹配的字符串排序,然后再把窗口中的字符进行排序,然后对比它们是不是相同的,这样就能判断了。

Java中的sort运用条件是需要转化字符串数组进行排序,需要注意。

class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        int len=p.length();
        List<Integer>ans=new ArrayList<Integer>();
        char[]you=p.toCharArray();
        Arrays.sort(you);
        String tiaojian=new String(you);
        for(int i=0;i<s.length()-len+1;i++){
            String buf=s.substring(i,i+len);
            char[]arr=buf.toCharArray();
            Arrays.sort(arr);
            String res=new String(arr);
            if(res.equals(tiaojian)){
                ans.add(i);
            }
        }
        return ans;
    }
}

思路二:也是滑动窗口的思路,但是不一样的是,我们这里的判断条件不一样了,定义两个数组进行比较,这两个数组一个表示s字符串中滑动窗口的字母频次,另一个则表示p字符串的字母频次。

我们这里用了双指针代表滑动窗口的模拟,当窗口长度为p字符串的长度的时候,我们就进行比较它们两个的频次数组是不是完全一样。如果一样,就说明是,把左指针指向的下标装入结果数组中;不是,就同时移动左指针和右指针一个单位,再次进行比较。

class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        int len1=s.length();
        int len2=p.length();
        List<Integer>ans=new ArrayList<Integer>();
        int[]a1=new int[26];
        int[]a2=new int[26];
        int l=0,r=0;
        for(int i=0;i<len2;i++)a2[p.charAt(i)-'a']++;
        while(r<len1){
            a1[s.charAt(r)-'a']++;
            if(r-l+1>len2)a1[s.charAt(l++)-'a']--;
            if(check(a1,a2))ans.add(l);
            r++;
        }
        return ans;
    }
    public boolean check(int[]s1,int[]s2){
        for(int i=0;i<26;i++){
            if(s1[i]!=s2[i])
            return false;
        }
        return true;
    }
}
相关推荐
蹉跎x2 分钟前
力扣1358. 包含所有三种字符的子字符串数目
数据结构·算法·leetcode·职场和发展
巫师不要去魔法部乱说1 小时前
PyCharm专项训练4 最小生成树算法
算法·pycharm
IT猿手1 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解GLSMOP1-GLSMOP9及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·算法·机器学习·matlab·强化学习
阿七想学习1 小时前
数据结构《排序》
java·数据结构·学习·算法·排序算法
王老师青少年编程2 小时前
gesp(二级)(12)洛谷:B3955:[GESP202403 二级] 小杨的日字矩阵
c++·算法·矩阵·gesp·csp·信奥赛
Kenneth風车2 小时前
【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)111
算法·机器学习·分类
eternal__day2 小时前
数据结构(哈希表(中)纯概念版)
java·数据结构·算法·哈希算法·推荐算法
APP 肖提莫2 小时前
MyBatis-Plus分页拦截器,源码的重构(重构total总数的计算逻辑)
java·前端·算法
OTWOL3 小时前
两道数组有关的OJ练习题
c语言·开发语言·数据结构·c++·算法
qq_433554543 小时前
C++ 面向对象编程:递增重载
开发语言·c++·算法