코딩테스트

[파이썬] 787. Cheapest Flights Within K Stops - 리트코드

Gogozzi 2022. 5. 31. 17:26
반응형

문제

 

시작점에서 도착점까지의 가장 저렴한 가격을 계산하되, K개의 경유지 이내에 도착하는 가격을 리턴하라. 경로가 존재하지 않을 경우 -1을 리턴한다.

예제 입력

Input: 
n = 4, 
flights = [[0,1,100],[1,2,100],[2,0,100],[1,3,600],[2,3,200]], 
src = 0, 
dst = 3, 
k = 1

예제 출력

Output: 700

작성한 코드

import heapq
from typing import List


def findCheapestPrice(n: int, flights: List[List[int]], src: int, dst: int, k: int) -> int:
    # 그래프 만들기
    adj_list = {i: [] for i in range(n)}
    for frm, to, price in flights:
        adj_list[frm].append((to, price))

    best_visited = [2 ** 31] * n 

    prior_queue = [(0, -1, src)]  # weight, steps, node

    while prior_queue:
        cost, steps, node = heapq.heappop(prior_queue)

        if best_visited[node] <= steps:
            continue

        if steps > k:  # 현재 스텝이 k 보다 크면 멈추기
            continue

        if node == dst:  # 원하는 도착지에 도착했을때 해당 금액을 반환
            return cost

        best_visited[node] = steps  # 업데이트

        for neighb, weight in adj_list[node]:
            heapq.heappush(prior_queue, (cost + weight, steps + 1, neighb))

    return -1

https://leetcode.com/problems/cheapest-flights-within-k-stops/

 

Cheapest Flights Within K Stops - LeetCode

Level up your coding skills and quickly land a job. This is the best place to expand your knowledge and get prepared for your next interview.

leetcode.com

 

반응형