【力扣hot100题】(010)滑动窗口最大值
在前几天笔试的时候做到了差不多的,就是将元素按顺序排,每次加入新元素时检查前面元素是否大于(小于)该元素,这样就能保持队列的单调性,然后要取最大(最小)值的时候直接取最前面的元素就行。(这道题每次取出元素前要判断队前元素序号是否超出滑动窗口前端)
需要用到一个新的东西deque(双端队列),笔试时使用的是stack(栈)。
class Solution {
public:
vector<int> maxSlidingWindow(vector<int>& nums, int k) {
vector<int> result;
deque<int> mp;
int high=0;
for(high;high<k;high++){
while(!mp.empty()&&nums[high]>=nums[mp.back()]) mp.pop_back();
mp.push_back(high);
}
result.push_back(nums[mp.front()]);
for(high;high<nums.size();high++){
while(!mp.empty()&&nums[high]>nums[mp.back()]) mp.pop_back();
mp.push_back(high);
while(mp.front()<=high-k) mp.pop_front();
result.push_back(nums[mp.front()]);
}
return result;
}
};
总之还是学到了新东西的,以前确实很少用过这个。
原文地址:https://blog.csdn.net/s478527548/article/details/146603258
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/613357.html 如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/613357.html 如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!