算法刷题:找到字符串中所有的字母异位词

找到字符串中所有的字母异位词

.

题目链接

找到字符串中所有的字母异位词

题目详情

题目解析

所谓的异位词,就是一个单词中的字母,打乱顺序,重新排列得到的单词

如:abc->bca

那么题目的目的就很明显了,就是要求在s字符串中找到p的异位词(相同组成,不同排列)

我们来模拟找一下

首先,定义两个指针,维护满足异位词的左右边界

使right往右移动

如图,在left与right之间,长度刚好符合p的异位词,此时,就需要对这个字符串进行校验,很,很明显,cba就属于p的异位词,校验成功,将当前异位词的首元素下标记录一下,然后使right继续往右移,但是此时子串的长度就不满足p的异位词了,因此,需要将left也往右移动一位

移动完成之后,此时子串的长度又满足条件了,进行校验,并不是p的异位词,继续移动,直到遍历完整个数组

很明显,整个过程通过两个指针,同向进行遍历来解决问题,而left与right之间,往右移动的过程,与窗口类似,因此我们考虑使用滑动窗口来实现这个过程

算法原理

滑动窗口流程图

定义指针及变量

定义两个指针:left和right,初始值都为0

创建hash表1,用数组模拟,记录p的每个字母出现的个数

创建hash表2,用数组模拟,用来记录子串(窗口)中各个字母出现的个数

定义变量count,来记录窗口中的有效字母的个数

创建链表来存储满足条件的异位词的下标

进窗口

将right所在的字母添加到hash2中,t添加完成之后

如果hash2[s[right]-'a']<=hash1[s[right]-'a']

说明当前字母是有效字母,就将count加一

判断

判断子串长度是否大于p的异位词的长度

出窗口

当窗口内子串长度大于p的异位词的长度的时候,需要将left所在的字母从hash2中减去1,在减去之前,需要再进行一层判断,判断hash2[s[left]-'a']<=hash1[s[left]-'a'],如果满足,说明减去的是有效字母,因此需要将count进行减一

更新结果

如果有效字母个数count等于p的字母个数,就说明满足p的异位词,将当前子串的下标存进链表中

我的答案

java 复制代码
class Solution {
    public List<Integer> findAnagrams(String ss, String pp) {
        //定义返回值
        List<Integer> list = new ArrayList<>();
        //将ss和pp转换为数组,方便遍历
        char[]s = ss.toCharArray();
        char[]p = pp.toCharArray();
        //创建hash1,统计p
        int[]hash1 = new int[26];
        for(char tmp:p){
            hash1[tmp-'a']++;
        }
        //创建hash2,用于统计s
        int[]hash2 = new int[26];
        //定义变量
        int count = 0;//记录有效字母个数
        for(int left = 0,right = 0;right<s.length;right++){
            //进窗口
            hash2[s[right]-'a']++;
            //维护有效字母个数
            if(hash2[s[right]-'a']<=hash1[s[right]-'a']) count++;
            //判断
            if(right-left+1>p.length){
                //出窗口
                //维护有效字母个数
                if(hash2[s[left]-'a']<=hash1[s[left]-'a']) count--;
                hash2[s[left]-'a']--;
                left++;
            }
            //更新结果
            if(count==p.length){
                list.add(left);
            }
        }
        return list;
    }
}
相关推荐
CSDN_RTKLIB几秒前
【std::map】与std::unordered_map差异
算法·stl·哈希算法
FL171713141 分钟前
Geometric Control
人工智能·算法
老鼠只爱大米4 分钟前
LeetCode算法题详解 283:移动零
算法·leetcode·双指针·快慢指针·移动零·move zeroes
过河卒_zh15667669 分钟前
喜讯:第十五批生成合成类算法备案备案号公布
人工智能·算法·aigc·生成式人工智能·算法备案
cpp_250112 分钟前
B3927 [GESP202312 四级] 小杨的字典
数据结构·c++·算法·题解·洛谷
Cx330❀15 分钟前
《C++ 递归、搜索与回溯》第2-3题:合并两个有序链表,反转链表
开发语言·数据结构·c++·算法·链表·面试
AI科技星16 分钟前
电磁耦合常数Z‘的第一性原理推导与严格验证:张祥前统一场论的几何基石
服务器·人工智能·线性代数·算法·矩阵
AI科技星20 分钟前
电场起源的几何革命:变化的引力场产生电场方程的第一性原理推导、验证与统一性意义
开发语言·人工智能·线性代数·算法·机器学习·数学建模
中國龍在廣州24 分钟前
“物理AI”吹响号角
大数据·人工智能·深度学习·算法·机器人·机器人学习
꧁Q༒ོγ꧂28 分钟前
算法详解(二)--算法思想基础
java·数据结构·算法