LeetCode hot100-438 找到字符串中所以字母异位词

滑动窗口

复制代码
class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
    int size1=s.size();
    int size2=p.size();
    if(size2>size1) return {};
    vector<int> pvt(26);
    vector<int> win(26);
    vector<int> idx;
    for(int i=0;i<size2;i++)
    {
        pvt[p[i]-'a']++;
        win[s[i]-'a']++;
    }
    if(pvt==win)
    {
        idx.emplace_back(0);
    }
    for(int i=1;i<size1-size2+1;i++)
    {
        win[s[i-1]-'a']--;
        win[s[i+size2-1]-'a']++;
        if(win==pvt)
        {
            idx.emplace_back(i);
        }
    }
    return idx;
 }
};

优化只用一个数组

复制代码
class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
    int size1=s.size();
    int size2=p.size();
    if(size2>size1) return {};
    vector<int> count(26);
    vector<int> idx;
    for(int i=0;i<size2;i++)
    {
        count[p[i]-'a']++;
        count[s[i]-'a']--;
    }

    if(allzero(count))
    {
        idx.emplace_back(0);
    }

    for(int i=1;i<size1-size2+1;i++)
    {
        count[s[i-1]-'a']++;//移出去
        count[s[i+size2-1]-'a']--;//加进来
        if(allzero(count))
        {
            idx.emplace_back(i);
        }
    }
    return  idx;
    }
private:
    bool allzero(vector<int>& count)
    {
        for(int c:count)
        {
            if(c!=0) return false;
        }
        return true;
    }
};
复制代码
vector<int> sum = {1, 2, 3, 4, 5};
    
    // ✅ 正确:使用 != 比较迭代器
    for(auto it = sum.begin(); it != sum.end(); it++) {
        cout << *it << " ";  // 解引用获取元素
    }
复制代码
// ✅ 最简洁的方式
for(auto num : sum) {
    cout << num << " ";
}

// 如果需要修改元素
for(auto& num : sum) {
    num *= 2;  // 修改元素
}
复制代码
string p = "hello";

// 遍历字符串中的每个字符
for(auto it : p) {
    cout << it << " ";  // it 是 char 类型
}
相关推荐
一只幸运猫.1 小时前
2026Java 后端面试完整版|八股简答 + AI 大模型集成技术(最新趋势)
人工智能·面试·职场和发展
Old Uncle Tom1 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆2 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移2 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业2 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
圣保罗的大教堂3 小时前
leetcode 1855. 下标对中的最大距离 中等
leetcode
智者知已应修善业4 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5485 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove5 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊5 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法