原題位址
給你乙個整數陣列 nums,有乙個大小為 k 的滑動視窗從陣列的最左側移動到陣列的最右側。你只可以看到在滑動視窗內的 k 個數字。滑動視窗每次只向右移動一位。
返回滑動視窗中的最大值。
示例 1:
輸入:nums = [1,3,-1,-3,5,3,6,7], k = 3示例 2:輸出:[3,3,5,5,6,7]
解釋:滑動視窗的位置 最大值
[1 3 -1] -3 5 3 6 7 3
1 [3 -1 -3] 5 3 6 7 3
1 3 [-1 -3 5] 3 6 7 5
1 3 -1 [-3 5 3] 6 7 5
1 3 -1 -3 [5 3 6] 7 6
1 3 -1 -3 5 [3 6 7] 7
輸入:nums = [1], k = 1示例 3:輸出:[1]
輸入:nums = [1,-1], k = 1示例 4:輸出:[1,-1]
輸入:nums = [9,11], k = 2示例 5:輸出:[11]
輸入:nums = [4,-2], k = 2看了挺多的題解, 還是有點很懵. 研究了一會兒(通過自己實踐), 終於弄明白了輸出:[4]
解決辦法:
基本原理:如果滑動視窗中的乙個數的右邊有比它大的數, 那麼這個數不是滑動視窗的最大值
因為右邊有比它大的數, 所以它現在不是最大值. 滑動時被選為最大值的情況, 只有在比它大的數全都被移除的時候. 但是滑動時左邊的數總是比右邊的數先被移除, 所以它再也沒有機會變成最大值了qwq
我們嘗試把這些不是最大值的數都刪除(見下圖, 紅色為剩餘的數, 紅框為滑動視窗):
此時發現, 剩餘的數構成了一組遞減數列, 因為剩下的數右邊都比它小(右邊有數比它大的都被刪除了嘛~)
這時, 滑動視窗的最大值非常好判斷了, 就是第乙個數.
那麼如何使用**模擬出這種刪除了不是最大值的數的數列的狀態呢?
答案就是使用佇列, 移除佇列尾直到佇列尾大於新元素, 記錄視窗每個元素在陣列中的下標, 根據頭尾下標差來判斷佇列頭是否應該被移除.
這樣就解決了問題.
**的話因為我還沒學queue, 所以暫時用arraylist替代(效率有點低, 但是執行的話也是能過的).
class solution
j++;
}while(j=k)
res[j-k+1]=tab.get(0);
j++;
}return res;}}
ps: 寫完隨筆感覺身體被掏空, 主要是那個叫draw.io的思維導圖工具使用方法還不夠熟悉. 而且而且, 我感覺有更為直觀的工具來表達我的思路(比如動態圖之類的), 但是目前我沒有找到合適的工具, 那麼寫題解的事情我覺得可以暫時緩一緩, 等到找到合適的工具了再來, 一來是為了表達更直觀, 二來也是為了效率.
嘛~就醬.
滑動視窗最大值
題目描述 給定乙個陣列和滑動視窗的大小,找出所有滑動視窗裡數值的最大值。例如,如果輸入陣列及滑動視窗的大小3,那麼一共存在6個滑動視窗,他們的最大值分別為 針對陣列的滑動視窗有以下6個 幾個注意點 利用雙端佇列實現,如果後者比前者大,前者丟擲,後者進,如果比前者小,壓入佇列,判斷隊頭是否過期,這就需...
滑動視窗最大值
給定乙個陣列和滑動視窗的大小,請找出所有滑動視窗裡的最大值。public class 滑動視窗的最大值 if num.length size size 1 用來儲存可能是滑動視窗最大值的數字的下標 linkedlist indexdeque newlinkedlist for int i 0 i s...
滑動視窗最大值
給定乙個陣列 nums,有乙個大小為 k 的滑動視窗從陣列的最左側移動到陣列的最右側。你只可以看到在滑動視窗內的 k 個數字。滑動視窗每次只向右移動一位。返回滑動視窗中的最大值。示例 輸入 nums 1,3,1,3,5,3,6,7 和 k 3 輸出 3,3,5,5,6,7 解釋 滑動視窗的位置 最大...