about summary refs log tree commit diff
path: root/users/wpcarro/scratch/facebook/mesh-message.py
blob: 8438b059d84328f84f049537af0f83f8ae01ed19 (plain) (blame)
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
from heapq import heappush, heappop
import random

def shortest_path(a, b, graph):
    seen = set()
    h = []
    heappush(h, (0, a, [a]))
    while h:
        km, x, path = heappop(h)
        if x == b:
            return path
        for c in graph[x]:
            if c not in seen:
                heappush(h, (km + 1, c, path + [c]))
    raise Exception("We were unable to find a path from {} to {}".format(a, b))

graph = {
    'Min'     : ['William', 'Jayden', 'Omar'],
    'William' : ['Min', 'Noam'],
    'Jayden'  : ['Min', 'Amelia', 'Ren', 'Noam'],
    'Ren'     : ['Jayden', 'Omar'],
    'Amelia'  : ['Jayden', 'Adam', 'Miguel'],
    'Adam'    : ['Amelia', 'Miguel', 'Sofia', 'Lucas'],
    'Miguel'  : ['Amelia', 'Adam', 'Liam', 'Nathan'],
    'Noam'    : ['Nathan', 'Jayden', 'William'],
    'Omar'    : ['Ren', 'Min', 'Scott'],
    'Liam'    : ['Ren'],
    'Nathan'  : ['Noam'],
    'Scott'   : [],
}

result = shortest_path('Jayden', 'Adam', graph)
print(result)
assert result == ['Jayden', 'Amelia', 'Adam']
print('Success!')

beg = random.choice(list(graph.keys()))
end = random.choice(list(graph.keys()))
print("Attempting to find the shortest path between {} and {}".format(beg, end))
print(shortest_path(beg, end, graph))