239 滑動視窗最大值 19 11 13

2021-09-29 14:27:51 字數 902 閱讀 9749

題目:

方法一:

利用大頂堆,每次把k個數放進堆裡,往右移,就把第乙個數移出,後面的數加入,陣列裡面加入堆頂元素。

class

solution})

;//初始化堆

if(nums.length==0)

if(maxheap.

size()

==0)}

int[

] array =

newint

[nums.length-k+1]

;for

(int i=

0;i(maxheap.

size()

!=0)return array;

}}

方法二:

利用雙向佇列,雙向佇列儲存最大元素的下標,每一次在滑動窗體中,如果新加元素比前面的元素大,就把前面元素清除,最終保證最左邊元素是最大的

239 滑動視窗最大值

給定乙個陣列 nums,有乙個大小為 k 的滑動視窗從陣列的最左側移動到陣列的最右側。你只可以看到在滑動視窗內的 k 個數字。滑動視窗每次只向右移動一位。返回滑動視窗中的最大值。示例 輸入 nums 1,3,1,3,5,3,6,7 和 k 3 輸出 3,3,5,5,6,7 解釋 滑動視窗的位置 最大...

239 滑動視窗最大值

239.滑動視窗最大值 solution deque solution maxindex 暴力法的時間複雜度為 o n k 弊端為每次掃瞄視窗的最大值,每兩次掃瞄之間都會存在重複的值比較,已經知道了他們的最大值是誰了,所以要減少比較次數 為什麼新增的是索引 將i加到隊尾 deque.addlast ...

239 滑動視窗最大值

給定乙個陣列 nums,有乙個大小為 k 的滑動視窗從陣列的最左側移動到陣列的最右側。你只可以看到在滑動視窗內的 k 個數字。滑動視窗每次只向右移動一位。返回滑動視窗中的最大值。高階 示例 輸入 nums 1,3,1,3,5,3,6,7 和 k 3 輸出 3,3,5,5,6,7 解釋 滑動視窗的位置...