LeetCode 热题 100 | 滑动窗口

目录

[1 3. 无重复字符的最长子串](#1 3. 无重复字符的最长子串)

[2 438. 找到字符串中所有字母异位词](#2 438. 找到字符串中所有字母异位词)


菜鸟做题第二周,语言是 C++

1 3. 无重复字符的最长子串

解题思路:

  1. 设置两个指针,左指针和右指针,二者之间形成窗口
  2. 右指针不断右移,新字母被纳入其中,窗口也变得越来越长
  3. 只有当窗口外的新字母与窗口内的字母重复时,左指针才右移
  4. 注意:在左指针右移前,还要利用它把重复的老字母去掉

用什么数据结构表示窗口?哈希表 unordered_set,帮助快速查重。

思路说明图:

假设在开始时 set/window 中只有一个字母 a 。第 1 时刻,right 指向的新字母 b 与窗口内的字母没有重复,因此将 b 纳入窗口中,right 右移一格。第 2 时刻,right 指向的新字母 c 与窗口内的字母没有重复,因此将 c 纳入窗口中,right 右移一格。第 3 时刻,right 指向的新字母 a 与窗口内的字母重复,这时 left 右移一格,起到去重的作用。以此类推。

那如何快速检验是否重复呢?借助哈希表的 find 或者 count 函数。

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int n = s.size();
        if (n == 0) return 0;

        unordered_set<char> set;
        set.insert(s[0]);

        int right = 1, len = 0;
        for(int left = 0; left < n; ++left) {
            while (right < n && set.find(s[right]) == set.end()) {
                set.insert(s[right]);
                ++right;
            }
            len = max(len, right - left);
            set.erase(s[left]);
        }
        return len;
    }
};

2 438. 找到字符串中所有字母异位词

我鼠啦,一直想着用哈希表减少时间,结果答案根本没用哈希表。。。因为该题中的字母是允许重复的,所以哈希表的查重功能貌似派不上用场。

解题思路:

  1. 窗口长度是固定的,且为 p 字符串的长度
  2. 让窗口在 s 字符串上不断右移
  3. 通过窗口内各字母的个数来判断是不是异位词

本题和上一题的窗口有两个不同点。一是,本题的窗口长度是固定的,而上一题的窗口是逐渐变长的;二是,本题的窗口被实例为 vector<int> 用于装 26 个字母的个数,而上一题的窗口直接用于装字母。

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

        if (sLen < pLen) return {};
        
        // 初始化窗口
        for (int i = 0; i < pLen; ++i) {
            ++sCount[s[i] - 'a'];
            ++pCount[p[i] - 'a'];
        }

        if (sCount == pCount) ans.push_back(0);
        
        // 不断右移窗口
        for (int i = 0; i < sLen - pLen; ++i) {
            --sCount[s[i] - 'a'];
            ++sCount[s[i + pLen] - 'a'];
            if (sCount == pCount) ans.push_back(i + 1);
        }

        return ans;
    }
};
相关推荐
py有趣37 分钟前
LeetCode算法学习之两数之和 II - 输入有序数组
学习·算法·leetcode
夏鹏今天学习了吗42 分钟前
【LeetCode热题100(62/100)】搜索二维矩阵
算法·leetcode·矩阵
吃着火锅x唱着歌3 小时前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
十八岁讨厌编程3 小时前
【算法训练营 · 补充】LeetCode Hot100(中)
算法·leetcode
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——最小覆盖字串
算法·c/c++·就业
wearegogog1233 小时前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法
网络·算法
Tiandaren4 小时前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
2301_795167205 小时前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效
开发语言·算法·rust
小当家.1055 小时前
[LeetCode]Hot100系列.贪心总结+思想总结
算法·leetcode·职场和发展
墨雪不会编程5 小时前
数据结构—排序算法篇二
数据结构·算法·排序算法