題目
型別:深搜 記憶化遞迴
難度:困難
題意:從乙個二維矩陣中找到乙個嚴格遞增的路徑。使用深度搜尋,不需要標記,因為到當前點是需要滿足比原來點數值大的,所以也不會重複遍歷。然後使用記憶化遞迴記錄最長的路徑,如果已經計算過了直接返回。
備註:2020.4.18位元組跳動三面面試題。面試官提示我使用回溯,其實沒必要,因為遞增這個條件限制了不可能會重複使用某個點。
class
solution
}return res;
}int dx[4]
=, dy[4]
=;intdfs
(int x,
int y, vectorint>>
& matrix)
}return mp[x]
[y];}}
;
329 矩陣中的最長遞增路徑
給定乙個整數矩陣,找出最長遞增路徑的長度。對於每個單元格,你可以往上,下,左,右四個方向移動。你不能在對角線方向上移動或移動到邊界外 即不允許環繞 示例 1 輸入 nums 9,9,4 6,6,8 2,1,1 輸出 4 解釋 最長遞增路徑為 1,2,6,9 示例 2 輸入 nums 3,4,5 3,...
329 矩陣中的最長遞增路徑
給定乙個整數矩陣,找出最長遞增路徑的長度。對於每個單元格,你可以往上,下,左,右四個方向移動。你不能在對角線方向上移動或移動到邊界外 即不允許環繞 示例 1 輸入 nums 9,9,4 6,6,8 2,1,1 輸出 4 解釋 最長遞增路徑為 1,2,6,9 dfs 記憶矩陣 儲存以該點位起點的最長路...
329 矩陣中的最長遞增路徑
2020 06 09 1.題目描述 矩陣中的最長遞增路徑2.題解 在這裡我們可以將其視作有向圖,如果當前的數比其四周位置上的數要小的話,就構建一條從當前數指向其 周圍的邊,要求得最長的遞增路徑,那麼其一定是從入度為0的點開始的,我們可以按照拓撲排序的邏輯,當 當前點的入度為0時,則入佇列,同時將與其...