經典圖論題 Amount of Time for Binary Tree to Be Infected_2385

閱讀時間約 6 分鐘

題目敘述

題目會給定我們一棵二元數Binary Tree的根結點。

並且給定感染的病毒源節點位置,每個單位時間,可以向相鄰的節點感染一次,問我們需要多少時間去感染整棵樹?

題目的原文敘述


測試範例

Example 1:

raw-image
Input: root = [1,5,3,null,4,10,6,9,2], start = 3
Output: 4
Explanation: The following nodes are infected during:
- Minute 0: Node 3
- Minute 1: Nodes 1, 10 and 6
- Minute 2: Node 5
- Minute 3: Node 4
- Minute 4: Nodes 9 and 2
It takes 4 minutes for the whole tree to be infected so we return 4.

Example 2:

raw-image
Input: root = [1], start = 1
Output: 0
Explanation: At minute 0, the only node in the tree is infected so we return 0.

約束條件

Constraints:

  • The number of nodes in the tree is in the range [1, 10^5].
  • 1 <= Node.val <= 10^5
  • Each node has a unique value.
  • A node with a value of start exists in the tree.

演算法

其實,二元樹Binary tree本身也是一種圖Graph,轉換成圖之後,要解開就非常容易了。

因為,最少需要多少時間去感染整棵樹 = 最少需要多少時間,去拜訪整張圖。

我們就把原本感染的問題映射到圖上的拜訪Traversal問題去解開來。


第一步:

先用DFS深度優先演算法建立整張圖,也就是把二元樹的連結關係相鄰陣列的方式來表達

第二步:

再用BFS廣度優先演算法,從感染的起點開始,拜訪整張圖,所需的時間就是感染整顆樹的時間。(BFS先天具有點波源擴散的性質)


程式碼

class Solution: 		
def amountOfTime(self, root: Optional[TreeNode], start: int) -> int:
graph = defaultdict(list)

# Build connected graph for binary tree in DFS
def dfs(node, parent):

if not node:
return

if parent:
graph[node.val].append(parent.val)
graph[parent.val].append(node.val)

dfs(node.left, node)
dfs(node.right, node)
return
#--------------------------------------
dfs(root, None)

# Start infection from start node, with BFS, which naturally has shortest path
bfs_queue = deque( [ (start, 0) ] )
visited = set([start])

while bfs_queue:

for _ in range( len(bfs_queue) ):
cur, step = bfs_queue.popleft()

for neighbor in graph[cur]:
if neighbor not in visited:
visited.add(neighbor)
bfs_queue.append( (neighbor, step+1) )

return step


關鍵知識點

二元樹Binary tree本身也是一種圖Graph,轉換成圖之後,要解開就非常容易了。

因為,最少需要多少時間去感染整棵樹 = 最少需要多少時間,去拜訪整張圖。


另外,BFS先天具有點波源擴散的性質,所以在無權重的圖中,也具有尋找最短路徑的特質。在這題,就是利用這個特質,來找出最少需要多少時間來拜訪整張圖(相當於感染整棵樹)


複雜度分析

時間複雜度:

O(n) DFS和BFS拜訪整張圖,每個節點至多分別拜訪一次,O(2n) = O(n)。

空間複雜度:

O(n) DFS和BFS拜訪整張圖,最大深度發生在整棵樹向左歪斜或者向右歪斜時 = O(n)。

另外,建立graph的相連矩陣時,也需要耗費O(n)的空間。


Reference:

[1] Python by DFS + BFS [w/ Comment]

53會員
342內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
發表第一個留言支持創作者!
你可能也想看
防曬產品係數測試報告彙整(2024年)從2014年起,自己對於市售防曬產品的效能產生了濃厚的興趣。因為當時候發現不少產品的防曬係數其實標示是有問題的,像是原本應該是人體測試的SPF與PA數值,實際上沒有做,只用機器測試的數據來充當,但這兩者卻有很大的差異。像是防曬係數其實有強度、廣度與平均度三個面向需要一起判斷,但多數廠商並沒有完整標示
Thumbnail
avatar
邱品齊皮膚科醫師
2023-04-27
樂讀.掛名推薦|收納回憶的經典圖鑑乍看之下會以為這本書偏搞笑類型,的確是有點搞笑,可是內容也是蠻豐富的喔,尤其是細讀作者在每一個動作之下的文字敘述,會覺得真的有認真仔細地觀察。收錄在書末與三浦純的對談也很有意思,最後兩人一起為這本書下了一個結論───
Thumbnail
avatar
陳子楹|樂*LOVE
2023-11-01
圖地︱WBC經典賽選手來自臺灣哪裡?用地圖一次看個清楚WBC棒球經典賽的選手來自臺灣各地,究竟哪裡的人最多呢?仔細研究可以發現,其中還有不少人是同一所小學畢業的。
Thumbnail
avatar
圖地
2023-03-20
經典杯子蛋糕with卡布奇諾(番外篇之一)跟外川第一次的意見不合就如此慘痛,野末從沒想過會是這種發展,也讓他深刻體驗到外川竟如此強勢(這就是年下攻嗎?)
Thumbnail
avatar
ShuShu
2023-02-25
暢銷超過44萬冊的日本經典圖書!一個禮物不夠,我還想要更多《兔子小白的禮物樹》|繪本深讀孩子們都很期待過聖誕節,因為這是一個可以拿禮物的日子,還可以欣賞漂亮的聖誕樹和閃亮亮的燈飾,真的是滿滿的幸福感呢。不過說到送禮物,每家規定不同,而禮物不嫌多,如果可以有更多禮物,誰會覺得不好呢!
Thumbnail
avatar
希望書盧:讀書讀繪本也讀生活,偶爾寫點電影的沙龍
2022-12-13
經典發想法6 心智圖發想法(純文字版) 企劃內容 要企劃拯救老舊書店大作戰 練習日期:2022/10/01 心智圖發想法(純文字版)練習方法 首先把要解決問題的關鍵字,寫出來, 接著我們再把和關鍵字有關的類別列出來, 作練習的過程當中如果中途想到甚麼, 都可以隨時補充! 點子大富翁們,開始練習吧! 關鍵字: 老舊書店
Thumbnail
avatar
逍遙遊
2022-10-01
複刻經典 鄂圖曼帝國之香之前去土耳其自由行時,意外發現當地香水文化非常興盛,而且最有趣的是,隨處可見各種香水專賣店不說,還不少標榜「複刻」經典專櫃品牌香水,媽媽我想長住土耳其!(毆)
Thumbnail
avatar
Eileen's
2022-09-08
圖解力的經典-圖解思考的本質歡迎大家來到圖解力的經典好書分享,我是你的圖解力教練奕霖! 談到圖像思維、視覺筆記,我們第一直覺聯想到的可能就像上面這張圖的筆記一樣,運用圖文方式整理資訊,讓內容變得吸睛、活潑、有趣、好記憶! 自2016年我接觸到視覺記錄到視覺筆記實踐的那幾年,我也是這麼想的。 一、 圖解思考的原則與元素  
Thumbnail
avatar
圖解力教練邱奕霖
2022-01-07
圖解力的經典-一張紙的整理術如何用一張紙,搞定工作報告、簡報設計、會議記錄、業務交接等職場大小事?作者在這本書中做了完整的詮釋,也讓我們看見了就算不會畫圖,也能透過圖像框架的思維,來有效提升我們工作生產力,歡迎大家可以動手來試試
Thumbnail
avatar
圖解力教練邱奕霖
2022-01-07
「頂級結構」CSGO經典爆破模式地圖的抽象原型 E 引言 很多即使不熟悉CSGO游戲的朋友或多或少地聽說過一些出圈的CSGO術語。 比如下面兩個經典的出圈梗 Rush B 中門對狙 當然了,絕大多數時候我們在使用這些梗的時候都帶著調侃或惡搞的意味。 事實上CSGO中的戰術遠不止於此,哪怕在戰術變化最單一的Dust2上也有著一些圈外
Thumbnail
avatar
穿過流水
2021-12-18
關於【留長髮的男生】試圖多一點理解女性經驗這種事從留長髮這件事,本宅慢慢發現何謂「男性凝視」,那些因為留長髮自然而然產生的動作,搖身一變成為「性感的象徵」。還給那些自然而然的動作該有的意義,是離開父權社會和男性凝視的一種方法,而縱使性別有無法跨越的鴻溝,我們依然能透過「確認自己不可能擁有的經驗」而畫出我們行使謙卑的範圍。
Thumbnail
avatar
牢騷肥宅
2021-02-08