Преобразование BFS в Джикстра, чтобы найти кратчайший путь - PullRequest
0 голосов
/ 18 февраля 2019

Как я могу преобразовать следующий алгоритм BFS, чтобы найти кратчайший путь с помощью Djikstra?Я знаю, что мне нужно обновить расстояния до соседей, но я не совсем понимаю, как именно расширить следующие BFS.Ограничение состоит в том, что мы можем двигаться только по L-образным путям между двумя узлами.

from collections import deque

N = 8
board_p = [[(-1,-1) for f in range(0,N)] for i in range(0,N)]

def Adjacents(u):    
    adj = []
    for e in [(-2,-1),(-2,1),(2,1),(2,-1),(-1,-2),(1,-2),(-1,2),(1,2)]:        
        v = (u[0] + e[0], u[1] + e[1])
        if v[0] >= 0 and v[0] < N and v[1] >= 0 and v[1] < N: adj.append(v)
    return adj;

def Moves(s,t):
    q = deque()
    q.append(s)
    board_p[s[0]][s[1]] = s # "root" of BFS-traversal points to it self (avoid loop over "back-edge" to s)
    while q:
        u = q.popleft()
        if u == t: break
        for v in Adjacents(u):
            if board_p[v[0]][v[1]] == (-1,-1):
                board_p[v[0]][v[1]] = u
                q.append(v)

    # walk the path back (using parent "pointers")
    path = [(t)]    
    while t != s:
        t = board_p[t[0]][t[1]]
        path.append(t)

    path.reverse()
    return path


print(Moves((1,1),(5,5)))
...