题目:

  1. 给定一个无向图graph,当这个图为二分图时返回true
  2. 如果我们能将一个图的节点集合分割成两个独立的子集AB,并使图中的每一条边的两个节点一个来自A集合
  3. ,一个来自B集合,我们就将这个图称为二分图。
  4. graph将会以邻接表方式给出,graph[i]表示图中与节点i相连的所有节点。
  5. 每个节点都是一个在0graph.length-1之间的整数。这图中没有自环和平行边:
  6. graph[i] 中不存在i,并且graph[i]中没有重复的值。
  7. 示例 1:
  8. 输入: [[1,3], [0,2], [1,3], [0,2]]
  9. 输出: true
  10. 解释:
  11. 无向图如下:
  12. 0----1
  13. | |
  14. | |
  15. 3----2
  16. 我们可以将节点分成两组: {0, 2} {1, 3}。
  17. 来源:力扣(LeetCode
  18. 链接:https://leetcode-cn.com/problems/is-graph-bipartite
  19. 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

答案:

时间:

10min

  1. class UnionFind:
  2. def __init__(self,n):
  3. self.parent = [i for i in range(n)]
  4. self.rank = [1 for _ in range(n)]
  5. self.count = n
  6. def find(self,p):
  7. while self.parent[p] != self.parent[self.parent[p]]:
  8. self.parent[p] = self.parent[self.parent[p]]
  9. return self.parent[p]
  10. def union(self,p,q):
  11. i = self.find(p)
  12. j = self.find(q)
  13. if i == j:
  14. return
  15. if self.rank [i] < self.rank [j]:
  16. self.parent[i] = j
  17. self.rank [j] += self.rank [i]
  18. else:
  19. self.parent[j] = i
  20. self.rank [i] += self.rank [j]
  21. self.count -= 1
  22. class Solution:
  23. def isBipartite(self, graph: List[List[int]]) -> bool:
  24. if not graph:return True
  25. n=len(graph)
  26. work= UnionFind(n)
  27. for j,node in enumerate(graph):
  28. m=len(node)
  29. if m==1:continue
  30. for i in range(1,m):
  31. work.union(node[i-1],node[i])
  32. for neighbour in node:
  33. if work.find(j)==work.find(neighbour):
  34. return False
  35. return True

要点:

1. 套用并查集模板

2. 二分图定义:

定义:一条边的两段属于两个集合
即一个点和他的邻居必然是两个集合

3. 算法过程:

遍历每个点的邻居集合,首先union他的所有邻居,再做一遍发现他的邻居和他是一个爹,就false

其他:

代码报错:无