-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoffline_1_mst.py
98 lines (81 loc) · 2.69 KB
/
offline_1_mst.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
from collections import defaultdict
import sys
def prim(graph):
mst = defaultdict(dict)
weights = {}
for i in graph:
mst[i] = []
# if ( graph[i]!={} ):
# min_weight = sys.maxsize
# min_key = 0
# for key in graph[i]:
# if graph[i][key]<min_weight:
# min_weight = graph[i][key]
# min_key = key
# mst[i].append(min_key)
# weights[i, min_key] = min_weight
# # visited.append(i)
# enqueue edges connected to s in PQ (by inc weight)
# while (!PQ.isEmpty)
# if (vertex v linked with e = PQ.remove ∉ T)
# T = T ∪ {v, e}, enqueue edges connected to v
# else ignore e
source = 1
front = []
visited = []
front.append(source)
while(front):
min_weight = sys.maxsize
for n in front:
for key in graph[n]:
if graph[n][key] < min_weight and key not in visited:
min_weight = graph[n][key]
min_key = key
min_n = n
if min_key not in visited:
front.append(min_key)
mst[min_n].append(min_key)
weights[min_n, min_key] = min_weight
visited.append(min_key)
if n not in visited:
visited.append(n)
for y in front:
x = [x for x in graph[y]]
if set(visited) > set(x):
front.remove(y)
# print("n: ",n , "y: ", y, "x:", x, "visited", visited)
# print("front:", front)
# if not x:
# min_weight = sys.maxsize
# for i in graph:
# if n in graph[i]:
# if graph[i][n] < min_weight:
# key = i
# min_weight = graph[i][n]
# if (key not in visited and min_weight!=sys.maxsize):
# mst[key].append(i)
# weights[key, i] = min_weight
# front.remove(n)
# elif set(visited)>set(x):
return mst, weights
if __name__ == '__main__':
# f = open('offline_1_input_1.txt')
f = open('offline_1_input_2_cp_4.14.txt')
num_of_vert = int(f.readline())
num_of_edge = int(f.readline())
graph = defaultdict(dict)
for i in range(1, num_of_vert + 1):
graph[i] = {}
for _ in range(0, num_of_edge):
line = f.readline().rstrip().split(" ")
graph[int(line[0])][int(line[1])] = int(line[2])
graph[int(line[1])][int(line[0])] = int(line[2])
mst, weights = prim(graph)
# print(mst)
for x in mst:
for y in mst[x]:
print (x, " ", y)
sum = 0
for x in weights:
sum += weights[x]
print(sum)