北美程序员面试干货

LeetCode 323 [Number of Connecte

2016-07-18  本文已影响234人  Jason_Yuan

原题

找出无向图中所有的连通块。
图中的每个节点包含一个label属性和一个邻接点的列表。(一个无向图的�连通块是一个子图,其中任意两个顶点通过路径相连,且不与整个图中的其它顶点相连。)

样例
给定图:

A------B  C
 \     |  | 
  \    |  |
   \   |  |
    \  |  |
      D   E

返回 {A,B,D}, {C,E}。其中有 2 个连通块,即{A,B,D}, {C,E}

解题思路

完整代码

# Method 1
# Definition for a undirected graph node
# class UndirectedGraphNode:
#     def __init__(self, x):
#         self.label = x
#         self.neighbors = []
class Solution:
    # @param {UndirectedGraphNode[]} nodes a array of undirected graph node
    # @return {int[][]} a connected set of a undirected graph
    def connectedSet(self, nodes):
        # Write your code here
        self.hashMap = {}
        for node in nodes:
            self.hashMap[node.label] = False
            
        res = []
        for node in nodes:
            if not self.hashMap[node.label]:
                temp = []
                self.dfs(node, temp)
                res.append(sorted(temp))
                
        return res
        
    def dfs(self, node, temp):
        self.hashMap[node.label] = True
        temp.append(node.label)
        for neighbor in node.neighbors:
            if not self.hashMap[neighbor.label]:
                self.dfs(neighbor, temp)
上一篇 下一篇

猜你喜欢

热点阅读