LeetCode 🟡 1367. Linked List in Binary Tree
🔗 🟡 1367. Linked List in Binary Tree 1650
tags: Weekly Contest 178
樹(Tree)
DFS
BFS
鏈結串列(Linked List)
二元樹(Binary Tree)
題意
給定一個二元樹的根節點 和一個鏈結串列的第一個節點 。
如果在二元樹中,存在一條一直向下的路徑,且每個點的數值恰好一一對應以 為首的鏈結串列中每個節點的值,那麼請你返回 True
,否則返回 False
。
一直向下的路徑的意思是:從樹中某個節點開始,一直連續向下的路徑。
思路:枚舉(Enumeration)
首先 簡化問題 。如果固定根結點 ,那麼我們只需要檢查是否存在一條從根節點一直向下的路徑,其數值一一對應鏈結串列中每個節點的值即可。為此我們可以定義一個遞迴函數 dfs(head, root)
,用於檢查從根節點 開始是否能匹配鏈結串列 。
- 如果鏈結串列已經匹配完(
head == nullptr
),返回True
- 如果樹已經走完但鏈結串列還沒匹配完(
root == nullptr
),返回False
- 如果當前根節點不匹配(
head.val != root.val
),返回False
- 否則,繼續檢查鏈結串列的下一個節點是否能匹配樹的左子節點或右子節點 (
dfs(head.next, root.left) or dfs(head.next, root.right)
)
由於樹上的任何一個節點都可以作為根節點,因此我們可以枚舉樹上的每一個節點,並調用 dfs
函數。只要有一條路徑匹配即可。故也能將 isSubPath
視為一個遞迴函數:
- 若從當前位置開始,則直接調用
dfs(head, root)
- 若從左右子樹開始,則遞迴調用
isSubPath(head, root.left)
和isSubPath(head, root.right)
需要注意,若 root
為空,則直接返回 False
,否則會造成遞迴無法結束。
複雜度分析
- 時間複雜度:,其中 是樹的節點數, 是鏈結串列的節點數。
- 在最壞情況下,我們需要遍歷二元樹的每一個節點,需要 的時間。
- 每次調用
dfs
函數最多需要檢查一棵高度為 的子樹,其最多有 個節點,但由於整棵樹的節點樹為 ,所以實際上我們需要檢查的節點數為兩者中的最小值。
- 空間複雜度:,其中 是樹的高度。
- 在調用
isSubPath
時,會遞歸調用dfs
函數,但在最壞情況下,遞迴深度還是不會超過樹的高度。
- 在調用
1 | class Solution: |
1 | class Solution { |
寫在最後
Cover photo is remixed from @吃肥皂泡泡, thanks for their work!
本部落格所有文章除特別聲明外,均採用CC BY-NC-SA 4.0 授權協議。轉載請註明來源 十六個天亮!
評論
WalineGiscus