我发现自己落入下面的mistakes,做了灵神的题单但是没有觉得算法能力提升。或者说总是在重复的地方卡住,就是因为没有回头复习以前做过的题目。
so,开启这个复习的小结栏目很有必要,再结合labuladong算法笔记,才能学得扎实。

1 温故而知新
自己重新写了一遍,这次的代码实现是:
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总结的有点不一样,这下再做一下这上面的题单试试。
4 总结
遇到了一点困难,我总结的模板是用于已知滑动窗口长度的,但是其实看leetcode3.就发现这个我自己总结的模板没有适用性,滑动窗口的长度就是我们要求的量,这要怎么办呢...回头再看看灵神的题单。啊,的确我只刷了定长的滑动窗口题单!😂!
(。_。)
...好在这不算我没学会的原因,只是没学而已,没关系,至少定长的会做了。
好好好,至少回头看看才知道刷题的方式不对,做完一个小专题就总结是好的,有自己总结出来的经验模板就可以差不多换一个专题了,没必要把所有题目都机械的做一遍过一遍。
加油(ง •_•)ง!