【力扣hot100题】(010)滑动窗口最大值

【力扣hot100题】(010)滑动窗口最大值_第1张图片

在前几天笔试的时候做到了差不多的,就是将元素按顺序排,每次加入新元素时检查前面元素是否大于(小于)该元素,这样就能保持队列的单调性,然后要取最大(最小)值的时候直接取最前面的元素就行。(这道题每次取出元素前要判断队前元素序号是否超出滑动窗口前端)

需要用到一个新的东西deque(双端队列),笔试时使用的是stack(栈)。

class Solution {
public:
    vector maxSlidingWindow(vector& nums, int k) {
        vector result;
        deque mp;
        int high=0;
        for(high;high=nums[mp.back()]) mp.pop_back();
            mp.push_back(high);
        }
        result.push_back(nums[mp.front()]);
        for(high;highnums[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;
    }
};

总之还是学到了新东西的,以前确实很少用过这个。

你可能感兴趣的:(leetcode,算法,职场和发展)