C++ | Leetcode C++题解之第438题找到字符串中所有字母异位词

题目:

题解:

cpp 复制代码
class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
        int sLen = s.size(), pLen = p.size();

        if (sLen < pLen) {
            return vector<int>();
        }

        vector<int> ans;
        vector<int> count(26);
        for (int i = 0; i < pLen; ++i) {
            ++count[s[i] - 'a'];
            --count[p[i] - 'a'];
        }

        int differ = 0;
        for (int j = 0; j < 26; ++j) {
            if (count[j] != 0) {
                ++differ;
            }
        }

        if (differ == 0) {
            ans.emplace_back(0);
        }

        for (int i = 0; i < sLen - pLen; ++i) {
            if (count[s[i] - 'a'] == 1) {  // 窗口中字母 s[i] 的数量与字符串 p 中的数量从不同变得相同
                --differ;
            } else if (count[s[i] - 'a'] == 0) {  // 窗口中字母 s[i] 的数量与字符串 p 中的数量从相同变得不同
                ++differ;
            }
            --count[s[i] - 'a'];

            if (count[s[i + pLen] - 'a'] == -1) {  // 窗口中字母 s[i+pLen] 的数量与字符串 p 中的数量从不同变得相同
                --differ;
            } else if (count[s[i + pLen] - 'a'] == 0) {  // 窗口中字母 s[i+pLen] 的数量与字符串 p 中的数量从相同变得不同
                ++differ;
            }
            ++count[s[i + pLen] - 'a'];
            
            if (differ == 0) {
                ans.emplace_back(i + 1);
            }
        }

        return ans;
    }
};
相关推荐
禁默37 分钟前
C++之stack 和 queue
开发语言·数据结构·c++
qmx_071 小时前
MFC - 常用基础控件
c++·mfc
兵哥工控1 小时前
MFC单按钮启停实例
c++·mfc
zyx没烦恼1 小时前
【C++】STL详解之string类
开发语言·c++
远望樱花兔2 小时前
【d54_2】【Java】【力扣】142.环形链表
java·leetcode·链表
潘潘潘潘潘潘潘潘潘潘潘潘2 小时前
【C++】类和对象(下)
c语言·开发语言·c++·学习方法
YRr YRr2 小时前
CMake 中 add_definitions() 使用的注意事项及替代方案
linux·c++·windows·cmake
小冉在学习2 小时前
leetcode刷题day32|动态规划Part01(509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯)
算法·leetcode·动态规划
做人不要太理性3 小时前
C++:模拟实现string
开发语言·c++
鸽芷咕3 小时前
【C++报错已解决】std::ios_base::floatfield
开发语言·c++·ios