Leetcode 81 【滑动窗口(定长)】

我发现自己落入下面的mistakes,做了灵神的题单但是没有觉得算法能力提升。或者说总是在重复的地方卡住,就是因为没有回头复习以前做过的题目。

so,开启这个复习的小结栏目很有必要,再结合labuladong算法笔记,才能学得扎实。

1 温故而知新

2379. 得到 K 个黑块的最少涂色次数

自己重新写了一遍,这次的代码实现是:

cpp 复制代码
class Solution {
public:
    int minimumRecolors(string blocks, int k) {
        int n = blocks.size();
        int cur = 0 ;

        for (int i = 0 ; i < k ; i++ ){
            if (blocks[i] == 'B'){
                cur++;
            }
        }

        int maxB = cur ;

        for (int i = k ; i < blocks.size() ; i++){
            if(blocks[i-k] == 'B'){
                cur --;
            }
            if(blocks[i] == 'B'){
                cur ++;
            }
            maxB = max(maxB ,cur );
        }



        return k - maxB ;
    }
};

2 自己总结出来的框架

伪代码

class Solution {

public:

int foo(vector<int>& arrs, int k) {

int n = arrs.size();

int cur = 0 ;

for (int i = 0 ; i < k ; i++ ){

初次滑动窗口

}

int res = cur ;

//把这个初始值赋值给我们的res,后续再更新

for (int i = k + 1 ; i < n - k ; ++i){

cur = cur - arrs[i - k - 1 ] + arrs[i + k];//这里就是滑动窗口进出以后的逻辑

...//结合题目自己更新res ,注意条件,总之在更新滑动窗口

//例如 res = max(cur , res);

}

return res ;

}

};

3 滑动窗口算法核心模板

https://labuladong.online/algo/essential-technique/sliding-window-framework/

和labuladong总结的有点不一样,这下再做一下这上面的题单试试。

LeetCode 力扣 难度
3. Longest Substring Without Repeating Characters 3. 无重复字符的最长子串 🟠
438. Find All Anagrams in a String 438. 找到字符串中所有字母异位词 🟠
567. Permutation in String 567. 字符串的排列 🟠
76. Minimum Window Substring 76. 最小覆盖子串 🔴

4 总结

遇到了一点困难,我总结的模板是用于已知滑动窗口长度的,但是其实看leetcode3.就发现这个我自己总结的模板没有适用性,滑动窗口的长度就是我们要求的量,这要怎么办呢...回头再看看灵神的题单。啊,的确我只刷了定长的滑动窗口题单!😂!

(。_。)

...好在这不算我没学会的原因,只是没学而已,没关系,至少定长的会做了。

好好好,至少回头看看才知道刷题的方式不对,做完一个小专题就总结是好的,有自己总结出来的经验模板就可以差不多换一个专题了,没必要把所有题目都机械的做一遍过一遍。

加油(ง •_•)ง!

相关推荐
搞笑症患者2 分钟前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
hunter14505 分钟前
windows server AD域与CA部署证书
笔记
im_AMBER6 分钟前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
予枫的编程笔记6 分钟前
【Java集合】深入浅出 Java HashMap:从链表到红黑树的“进化”之路
java·开发语言·数据结构·人工智能·链表·哈希算法
快手技术23 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱25 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
Mr -老鬼26 分钟前
Rust与Go:从学习到实战的全方位对比
学习·golang·rust
laplace012326 分钟前
# 第四章|智能体经典范式构建 —— 学习笔记(详细版)
笔记·学习
做科研的周师兄27 分钟前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
程序猿零零漆27 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(十四)SpringMVC的请求处理
学习·spring·pandas