LeetCode 筆記 - 2369. Check if There is a Valid Partition For The Array
題目在此 2369. Check if There is a Valid Partition For The Array
給一個數列,請問是否可以讓所有 subarray 皆符合以下三個條件:
- subarray 的長度為 2,且數字相同
- subarray 的長度為 3,且數字相同
- subarray 的長度為 3,且相鄰元素為相差 1 的遞增,例如
[1, 2, 3]
為合法 subarray,[1, 4, 5]
則不是。
解題思維
名詞解說:
- Depth First Search
- Dynamic Programming
我相信 Dynamic Programming 會是多數人的魔王,因為他的解法很多時候都是看不懂的,鬼才看得懂。
當然你也可以很直覺地用 Depth First Search 來解,但是這題的 DFS 會超時,所以我們還是來看 DP 吧!
step 1: 讓 dp[i]
代表以 i
為結尾的 subarray 是否合法,如果合法則為 True,否則為 False。
step 2: 所以如果在任意 i
時,當 dp[i - 2]
為 True 時,表示可以檢查 nums[i - 1] == nums[i]
,如果是的話,則 dp[i]
為 True。
當 dp[i - 3]
為 True 時,表示可以檢查 nums[i - 2] == nums[i - 1] == nums[i]
,如果是的話,則 dp[i]
為 True。
或 nums[i - 2] == nums[i - 1] - 1 and nums[i - 1] == nums[i] - 1
,如果是的話,則 dp[i]
為 True。
step 3: 最後回傳 dp[-1] 即可。
程式碼
1 | class Solution: |