-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday12_1.py
117 lines (75 loc) · 2.09 KB
/
day12_1.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
99
100
101
102
103
104
105
106
def inp():
d = {}
for line in open("input_d12.txt", "rt"):
line = line.replace("\n", "")
line = line.split("-")
if line[0] not in d.keys():
d[line[0]] = [line[1]]
else:
d[line[0]].append(line[1])
if line[1] not in d.keys():
d[line[1]] = [line[0]]
else:
d[line[1]].append(line[0])
return d
def info(d):
for key in d.keys():
print(f"{key} -> {d[key]}")
def makeVisited(graph):
tmp = {}
for key in graph.keys():
tmp[key] = False
return tmp
def visitNode(name, graph, visited):
global f
global path
path.append(name)
#for val in path:
# print(f"{val} ", end="")
#print("")
if visited[name]:
del path[-1]
#print(f"*going back*\tvisited[{name}]==True\n")
#for val in path:
# print(f"{val} ", end="")
#print("")
return
if name != name.upper():
visited[name] = True
if name == "end":
visited[name] = False
global paths
paths += 1
global endpaths
endpaths.append(path.copy())
del path[-1]
#print(f"*going back*\tname=='end'\n")
#for val in path:
# print(f"{val} ", end="")
#print("")
return
if False not in [visited[n] for n in graph[name]]:
visited[name] = False
del path[-1]
#print(f"*going back*\t{name} has no more neighbours\n")
#for val in path:
# print(f"{val} ", end="")
#print("")
return
for neighbour in graph[name]:
isUppercase = (neighbour == neighbour.upper())
if visited[neighbour] == False or isUppercase:
visitNode(neighbour, graph, visited)
visited[name] = False
del path[-1]
#print(f"*going back*\tend of funtion at {name}")
return
graph = inp()
visited = makeVisited(graph)
endpaths = []
paths = 0
path = []
visitNode("start", graph, visited)
print(paths)
#for p in endpaths:
# print(p)