Leetcode 438. 找到字符串中所有字母异位词(java实现)

解题思路:滑动窗口。

异位词的典型解题方法就是用数组来统计出现的个数。本题也不例外。

直接上代码来进行讲解:

java 复制代码
  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;

    }

可能有同学对这里的代码不是太理解是干嘛的,我们来举个例子就好理解了。

假如我们的测试用例是下面的:

java 复制代码
String s = "cbaebabacd";String p = "abc";

我们经过两个for循环之后,也就是统计字符出现的次数。
arrcur分别是下面的结果:

cur中统计的是cb两个字符,进入下面的for循环第一步就是把right所指的地方的a字符假加入到cur数组中,然后进行比较,比较后,再把c字符删去。每次循环的时候cur都是两个字符,然后加入一个字符判断,判断完毕之后再删除一个字符。

如果觉得还不是很理解,建议debug下自己尝试下,本题需要注意的点就是cur数组统计字符的时候最开始是统计两个。然后就是上面的每次cur数组中的加入字符和减去字符的代码,需要理解清楚。

相关推荐
码云骑士几秒前
12-GIL不是性能杀手(下)-绕过GIL的三种方案与决策树
算法·决策树·机器学习
一只齐刘海的猫3 分钟前
【Leetcode】无重复字符的最长子串
算法·leetcode·职场和发展
行智科技4 分钟前
FAST-LIVO2 源码精读(二):环境搭建与编译避坑
算法·ubuntu·自动驾驶·slam
重生之我是Java开发战士8 分钟前
【Java SE】多线程(三):单例模式,阻塞队列,线程池与定时器
java·javascript·单例模式
AI人工智能+电脑小能手12 分钟前
【大白话说Java面试题 第115题】【并发篇】第15题:说一下悲观锁和乐观锁的区别?
java·开发语言·面试
插件开发15 分钟前
vs2015 cuda c++ cdpSimplePrint范例,递归功能实现演示
linux·c++·算法
Tisfy16 分钟前
LeetCode 2130.链表最大孪生和:转数组 / 快慢指针+链表翻转(O(1))
算法·leetcode·链表·题解
心之伊始25 分钟前
Spring Boot Actuator + Micrometer 实战:自定义业务指标并接入 Prometheus 观测接口耗时
java·spring boot·prometheus·actuator·micrometer
Full Stack Developme29 分钟前
Spring Integration 教程
java·后端·spring
摇滚侠36 分钟前
MyBatis 入门到项目实战 MyBatis 分页插件 65-66
java·开发语言·sql·mybatis