答案:使用双端队列维护单调递增序列,遍历时移除过期下标和较大值下标,窗口形成后队首即为最小值。例如输入 nums = [2,1,3,-1,-2,5,4], k = 3,输出 [1,-1,-2,-2,-2],时间复杂度 O(n)。

在 C++ 中,可以使用双端队列(deque)结合栈的思想来高效实现滑动窗口最小值问题。虽然题目提到“栈”,但实际更合适的数据结构是双端队列,因为它支持两端操作,能模拟单调栈的行为。
// 滑动窗口最小值实现
#include <vector>
#include <deque>
using namespace std;
vector<int> minSlidingWindow(vector<int>& nums, int k) {
vector<int> result;
deque<int> dq; // 存储下标,保证对应值递增
for (int i = 0; i < nums.size(); ++i) {
// 移除不在窗口内的下标
while (!dq.empty() && dq.front() <= i - k) {
dq.pop_front();
}
// 从队尾移除比当前值大的元素下标
while (!dq.empty() && nums[dq.back()] >= nums[i]) {
dq.pop_back();
}
dq.push_back(i); // 加入当前下标
// 窗口形成后记录最小值
if (i >= k - 1) {
result.push_back(nums[dq.front()]);
}
}
return result;
}
基本上就这些。用 deque 模拟单调栈行为是解决滑动窗口最值的标准做法,效率高且易于理解。
以上就是c++++中如何使用栈实现滑动窗口最小值_c++栈实现滑动窗口最小值的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号