본문 바로가기

Algorithm/Shortest Way

화성 탐사

 

 

유형 파악 및 구현

이 문제는 우선, 한 노드에서 다른 노드로 가는 최단 경로를 구하는 문제이다.

따라서, 다익스트라 알고리즘을 통해 해결한다.

모든 노드에 대해서 첫번째 노드와의 최단경로를 구하면서 마지막 노드까지가서 결과적으로는 첫노드와 마지막노드의 최단경로를 구하는 것이다.

 

아래의 distance 배열은 노드 [0, 0]과의 거리를 의미한다.

 

 

코드

import heapq

n = 7
graph = [
    [9, 0, 5, 1, 1, 5, 3],
    [4, 1, 2, 1, 6, 5, 3],
    [0, 7, 6, 1, 6, 8, 5],
    [1, 1, 7, 8, 3, 2, 3],
    [9, 4, 0, 7, 6, 4, 1],
    [5, 8, 3, 2, 4, 8, 3],
    [7, 4, 8, 4, 8, 3, 4]
]

INF = int(1e9)
dx = [-1, 0, 1, 0]
dy = [0, -1, 0, 1]

start = [0, 0]
cost = graph[start[0]][start[1]]
q = []
heapq.heappush(q, [cost, start])
distance = [[INF]*n for _ in range(n)]
distance[start[0]][start[1]] = cost

while q:
    now_cost, now_pos = heapq.heappop(q)
    # 현재 노드가 굳이 처리할 필요가 없는 노드라면 패스
    if now_cost > distance[now_pos[0]][now_pos[1]]:
        continue
    for i in range(4):
        next_x = now_pos[0] + dx[i]
        next_y = now_pos[1] + dy[i]
        if next_x < 0 or next_x >= n or next_y < 0 or next_y >= n:
            continue
        next_cost = now_cost + graph[next_x][next_y]
        # 굳이 지금 가는 길이 갈 필요가 있는지 없는지 체크한다 생각
        if distance[next_x][next_y] > next_cost:
            distance[next_x][next_y] = next_cost
            heapq.heappush(q, [next_cost, [next_x, next_y]])

for i in distance:
    print(i)

 

 

 

 

 

'Algorithm > Shortest Way' 카테고리의 다른 글

숨바꼭질  (0) 2023.04.13
정확한 순위  (0) 2023.04.13
플로이드  (0) 2023.04.12
전보  (0) 2023.04.12
미래 도시  (0) 2023.04.12