-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
39 lines (26 loc) · 1.18 KB
/
main.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
from mygraph import MyGraph
def get_graph(voters):
graph = MyGraph(graph_type='graph', size='20,11.25!', ratio='fill')
graph.add_cluster("unknows", "Votos a serem apurados")
for v in range(1,voters+1):
graph.add_nodes(v)
graph.add_nodes_cluster("unknows", v)
return graph
voters = int(input("Insira o número de eleitores do município: "))
relations = int(input("Insira o número de relações conhecidas: "))
graph = get_graph(voters)
for r in range(relations):
a, b = map(int, input('\tInsira dois eleitores relacionados: ').split())
graph.link(a, b)
know_votes = int(input("Insira o número de votos apurados: "))
if know_votes:
E = map(int, input("Insira os eleitores que declararam seus votos: ").split())
graph.add_cluster("knows", "Votos com valor conhecido")
for v in E:
graph.bfs(v, 'darkolivegreen3', "knows")
print(f"Para ter 100% de acurácia é preciso conhecer os votos de {graph.count_not_checked_components('brown2')} eleitores!")
file_name = input("Escolha um nome para o seu gif: ")
img_name = "graph"
graph.save_gif(file_name)
graph.save_img(img_name)
print(f"Parabéns! Seu gif foi salvo em {file_name}.gif!")