2021-08-02 20:40:48 +08:00
|
|
|
def kruskal(
|
|
|
|
num_nodes: int, edges: list[tuple[int, int, int]]
|
|
|
|
) -> list[tuple[int, int, int]]:
|
2020-10-16 03:08:52 +08:00
|
|
|
"""
|
2021-08-02 20:40:48 +08:00
|
|
|
>>> kruskal(4, [(0, 1, 3), (1, 2, 5), (2, 3, 1)])
|
2020-10-16 03:08:52 +08:00
|
|
|
[(2, 3, 1), (0, 1, 3), (1, 2, 5)]
|
|
|
|
|
2021-08-02 20:40:48 +08:00
|
|
|
>>> kruskal(4, [(0, 1, 3), (1, 2, 5), (2, 3, 1), (0, 2, 1), (0, 3, 2)])
|
2020-10-16 03:08:52 +08:00
|
|
|
[(2, 3, 1), (0, 2, 1), (0, 1, 3)]
|
|
|
|
|
2021-08-02 20:40:48 +08:00
|
|
|
>>> kruskal(4, [(0, 1, 3), (1, 2, 5), (2, 3, 1), (0, 2, 1), (0, 3, 2),
|
2020-10-16 03:08:52 +08:00
|
|
|
... (2, 1, 1)])
|
|
|
|
[(2, 3, 1), (0, 2, 1), (2, 1, 1)]
|
|
|
|
"""
|
2020-10-08 20:21:48 +08:00
|
|
|
edges = sorted(edges, key=lambda edge: edge[2])
|
2018-10-19 20:48:28 +08:00
|
|
|
|
2019-07-17 12:07:25 +08:00
|
|
|
parent = list(range(num_nodes))
|
2018-10-19 20:48:28 +08:00
|
|
|
|
2019-07-17 12:07:25 +08:00
|
|
|
def find_parent(i):
|
2019-10-05 13:14:13 +08:00
|
|
|
if i != parent[i]:
|
|
|
|
parent[i] = find_parent(parent[i])
|
|
|
|
return parent[i]
|
2018-10-19 20:48:28 +08:00
|
|
|
|
2019-07-17 12:07:25 +08:00
|
|
|
minimum_spanning_tree_cost = 0
|
|
|
|
minimum_spanning_tree = []
|
2018-10-19 20:48:28 +08:00
|
|
|
|
2019-07-17 12:07:25 +08:00
|
|
|
for edge in edges:
|
2020-10-08 20:21:48 +08:00
|
|
|
parent_a = find_parent(edge[0])
|
|
|
|
parent_b = find_parent(edge[1])
|
2019-10-05 13:14:13 +08:00
|
|
|
if parent_a != parent_b:
|
2020-10-08 20:21:48 +08:00
|
|
|
minimum_spanning_tree_cost += edge[2]
|
2019-10-05 13:14:13 +08:00
|
|
|
minimum_spanning_tree.append(edge)
|
|
|
|
parent[parent_a] = parent_b
|
2019-07-17 12:07:25 +08:00
|
|
|
|
2020-10-08 20:21:48 +08:00
|
|
|
return minimum_spanning_tree
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__": # pragma: no cover
|
|
|
|
num_nodes, num_edges = list(map(int, input().strip().split()))
|
|
|
|
edges = []
|
|
|
|
|
|
|
|
for _ in range(num_edges):
|
|
|
|
node1, node2, cost = [int(x) for x in input().strip().split()]
|
|
|
|
edges.append((node1, node2, cost))
|
|
|
|
|
2021-08-02 20:40:48 +08:00
|
|
|
kruskal(num_nodes, edges)
|