在本問題中, 樹指的是乙個連通且無環的無向圖。
輸入乙個圖,該圖由乙個有著n個節點 (節點值不重複1, 2, ..., n) 的樹及一條附加的邊構成。附加的邊的兩個頂點包含在1到n中間,這條附加的邊不屬於樹中已存在的邊。
結果圖是乙個以邊組成的二維陣列。每乙個邊的元素是一對[u, v] ,滿足 u < v,表示連線頂點u 和v的無向圖的邊。
返回一條可以刪去的邊,使得結果圖是乙個有著n個節點的樹。如果有多個答案,則返回二維陣列中最後出現的邊。答案邊 [u, v] 應滿足相同的格式 u < v。
示例 1:
輸入: [[1,2], [1,3], [2,3]]
輸出: [2,3]
解釋: 給定的無向圖為:
1/ \
2 - 3
示例 2:
輸入: [[1,2], [2,3], [3,4], [1,4], [1,5]]
輸出: [1,4]
解釋: 給定的無向圖為:
5 - 1 - 2
| |
4 - 3
注意:輸入的二維陣列大小在 3 到 1000。
二維陣列中的整數在1到n之間,其中n是輸入陣列的大小。
解題思路:
使用並查集解決。遍歷每一條邊,找到每個node的根節點,如果一條邊的兩個node的根節點是同一節點,那麼這條邊就是冗餘的,最後找到的這條邊就是要刪去的邊。
LeetCode684冗餘連線
在本問題中,樹指的是乙個連通且無環的無向圖。輸入乙個圖,該圖由乙個有著n個節點 節點值不重複1,2,n 的樹及一條附加的邊構成。附加的邊的兩個頂點包含在1到n中間,這條附加的邊不屬於樹中已存在的邊。結果圖是乙個以邊組成的二維陣列。每乙個邊的元素是一對 u,v 滿足u v,表示連線頂點u和v的無向圖的...
leetcode 684冗餘連線
在本問題中,樹指的是乙個連通且無環的無向圖。輸入乙個圖,該圖由乙個有著n個節點 節點值不重複1,2,n 的樹及一條附加的邊構成。附加的邊的兩個頂點包含在1到n中間,這條附加的邊不屬於樹中已存在的邊。結果圖是乙個以邊組成的二維陣列。每乙個邊的元素是一對 u,v 滿足u v,表示連線頂點u和v的無向圖的...
LeetCode 684 冗餘連線
原題目 思路 並查集,每次檢查邊的兩個頂點是否屬於同乙個集合,如果是,則返回 形成了環 如果不是,將這兩個頂點併入到乙個集合之中,依次檢查所有的邊。可以同時考慮路徑壓縮,每次合併的時候都合併到size大的節點。class unionfind int find int p return p void ...