/*
给定一个长度为 n 的数组 nums 和滑动窗口的大小 size ,找出所有滑动窗口里数值的最大值。
例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6,5}; 针对数组{2,3,4,2,6,2,5,1}的滑动窗口有以下6个: {[2,3,4],2,6,2,5,1}, {2,[3,4,2],6,2,5,1}, {2,3,[4,2,6],2,5,1}, {2,3,4,[2,6,2],5,1}, {2,3,4,2,[6,2,5],1}, {2,3,4,2,6,[2,5,1]}。
*/
vector<int> maxInWindows(const vector<int>& num, int size) {
vector<int> ret;
// int n = num.size();
// deque<int> dq;
// for(int i = 0; i < n; i++) {
// while(!dq.empty() && num[dq.back()] < num[i])
// dq.pop_back();
// dq.push_back(i);
// if(i - dq.front() >= size)
// dq.pop_front();
// if(i + 1 >= size)
// ret.push_back(num[dq.front()]);
// }
if (num.size() == 0 || size < 1 || num.size() < size) return ret;
int n = num.size();
deque<int> dq;
queue<int> sta;
//sta.pop()
for (int i = 0; i < n; ++i) {
//将窗口中小于当前num[i]的均弹出,使得栈保持单调递增,因为在包含i的所有窗口中的最大值一定大于等于num[i];
while (!dq.empty() && num[dq.back()] < num[i]) {
dq.pop_back();
}
//将mum[i]压入
dq.push_back(i);
// 判断队列的头部的下标是否过期
if (dq.front() + size <= i) {
dq.pop_front();
}
// 判断是否形成了窗口
if (i + 1 >= size) {
ret.push_back(num[dq.front()]);
}
}
return ret;
}
BM45 滑动窗口的最大值(单调栈的代码框架
最新推荐文章于 2023-04-26 20:36:58 发布