前言:
本系列是看的B站董晓老师所讲的知识点做的笔记
董晓算法的个人空间-董晓算法个人主页-哔哩哔哩视频 (bilibili.com)
C单调队列
P1886 滑动窗口 /【模板】单调队列 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
k为窗口的大小
维护最小值就是维护窗口内的升序子序列
维护最大值就是维护窗口内的降序子序列
思想:
q[]数组中存放的是元素的下标,队尾出队(判断大小)进队(存入下标),对头出队(判断距离)
// 维护窗口最小值
int h=1, t=0; //头尾指针初值
for(int i=1; i<=n; i++){
while(h<=t && a[q[t]]>=a[i]) t--; //队尾出队(队列不空且新元素更优)
q[++t]=i; //队尾入队(存储下标 方便判断队头出队)
if(q[h]<i-k+1) h++; //队头出队(队头元素滑出窗口)
if(i>=k) printf("%d ", a[q[h]]); //输出最值
}