
在前几天笔试的时候做到了差不多的,就是将元素按顺序排,每次加入新元素时检查前面元素是否大于(小于)该元素,这样就能保持队列的单调性,然后要取最大(最小)值的时候直接取最前面的元素就行。(这道题每次取出元素前要判断队前元素序号是否超出滑动窗口前端)
需要用到一个新的东西deque(双端队列),笔试时使用的是stack(栈)。
cpp
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;
}
};
总之还是学到了新东西的,以前确实很少用过这个。