Leetcode每日刷题之438.找到字符串中所有字符异位词

1.题目解析

本题的题目要求是给定一个长字符串s与一个较短字符串p,判断s中是否有一段与p长度相同的字符串是由p打乱而得来,即为异位词,然后返回其开始位置下标,遍历s字符串中所有满足条件字符串的起始位置下标

2.算法原理

我们将p中的字符串个数统计在一个哈希表里,然后使用"滑动窗口"的思想来遍历p字符串中的异位词,此时设置一个变量count来统计窗口内有效字符的个数,如果窗口内有效字符的个数满足p字符串长度则为异位词,返回其下标即可,然后向后遍历直到结束

3.代码展示

cpp 复制代码
class Solution {
public:
    vector<int> findAnagrams(string s, string p) 
    {
        vector<int> v;
        int hash1[26] = { 0 };
        int hash2[26] = { 0 };//统计窗口中出现字符的个数
        for(auto ch : p)
        {
            hash1[ch - 'a']++;//统计p中字符串长度
        }
        int m = p.size();
        int n = s.size();
        for(int left = 0,right = 0,count = 0;right < n;right++)
        {
            char in = s[right];
            if(++hash2[in - 'a'] <= hash1[in - 'a'])
            {
                count++;//进窗口 + 维护 count 
            }
            if(right - left + 1 > m)
            {
                char out = s[left++];
                if(hash2[out - 'a']-- <= hash1[out - 'a'])
                {
                    count--;//出窗口 + 维护 count 
                }
            }
            if(count == m)
            {
                v.push_back(left);
            }
        }
        return v;
    }
};
相关推荐
逆境不可逃4 分钟前
LeetCode 热题 100 之 394. 字符串解码 739. 每日温度 84. 柱状图中的最大矩形
算法·leetcode·职场和发展
sycmancia10 分钟前
C++——动态内存分配、关于虚函数、关于继承中的强制类型转换
开发语言·c++
重生之后端学习18 分钟前
62. 不同路径
开发语言·数据结构·算法·leetcode·职场和发展·深度优先
小资同学20 分钟前
考研机试 -Kruskal算法
算法
y芋泥啵啵gfe22 分钟前
AI考研深造VS直接工作:选对赛道,认证为竞争力加码
人工智能·职场和发展
big_rabbit050223 分钟前
[算法][力扣283]Move Zeros
算法·leetcode·职场和发展
小资同学25 分钟前
考研机试动态规划 线性DP
算法·动态规划
listhi52030 分钟前
两台三相逆变器并联功率分配控制MATLAB实现
算法
Evand J33 分钟前
【IMM】非线性目标跟踪算法与MATLAB实现:基于粒子滤波的交互式多模型,结合CV和CT双模型对三维空间中的机动目标进行高精度跟踪
算法·matlab·目标跟踪·pf·粒子滤波·imm·多模型
重生之后端学习34 分钟前
64. 最小路径和
数据结构·算法·leetcode·排序算法·深度优先·图论