给定一个数组和k大小的滑动窗口,找出所有滑动窗口里的最大值。...例如:nums={7, 2, 4, 5, 1} , k=2
结果:result={7, 4, 5, 5}
图解如下:
分析下:
这道题需要保存一个值的集合,因为随着滑动窗口的移动,最大值会被移除窗口,...次大值会变成最大值;为了方便最大值的比较,最好是个有序的集合....对以上述的值集合还需要方便查询和删除最大值以及插入新值,并维护集合的有序性.
满足以上两个条件的数据结构是单调递减双向队列,虽然名字长,但也很好理解的....滑动窗口右移
要压入的元素5比队尾元素4大,弹出4,压入5;
队首元素为5,即滑动窗口中的最大值为5;
5. 滑动窗口右移
队尾压入元素1;
取队首元素5为滑动窗口最大值.