Coding Test/Programmers

[프로그래머스] 합승 택시 요금(java)

Heang Lee 2021. 5. 27. 21:42

코딩테스트 연습 - 합승 택시 요금 | 프로그래머스 (programmers.co.kr)

어떻게 생각하고 문제를 풀었는가?

지점 k에서 A와 B가 택시를 따로 이용하여 목표지점으로 가는 경우 s->k까지의 최소비용 + k->A까지의 최소비용 + k->B까지의 최소비용으로 계산할 수 있습니다.

택시요금은 방향에 따라 달라지지 않습니다. 따라서 s에서 시작하여 각 지점까지의 최소비용, A에서 시작하여 각 지점까지의 최소 비용, B에서 시작하여 각 지점까지의 최소 비용을 미리 계산한 후 모든 k에 대한 비용 중 최소 값을 찾음으로서 전체 최소요금을 구할 수 있습니다.

코드

import java.util.*;
class Solution {
    final int MAX = 20000001;
    int[][] lines;
    public int solution(int n, int s, int a, int b, int[][] fares) {
        lines = new int[n][n];
        for(int[] fare : fares){
            lines[fare[0]-1][fare[1]-1] = fare[2];
            lines[fare[1]-1][fare[0]-1] = fare[2];
        }
        int[] dijkS = dijkstra(s-1,n);
        int[] dijkA = dijkstra(a-1,n);
        int[] dijkB = dijkstra(b-1,n);
        int answer=MAX;
        for(int i=0;i<n;i++){
            int cost =dijkS[i]+dijkA[i]+dijkB[i]; 
            if(answer>cost) answer = cost;
        }
        return answer;
    }
    public int[] dijkstra(int start,int n){
        PriorityQueue<int[]> pq = new PriorityQueue<>((x,y)->x[1]-y[1]);
        pq.add(new int[]{start,0});
        int[] result = new int[n];
        Arrays.fill(result,MAX);
        result[start]=0;
        while(!pq.isEmpty()){
            int[] curr = pq.poll();
            if(curr[1] > result[curr[0]]) continue;   //방문하는 의미가 없음
            for(int i=0;i<n;i++){
                int cost = lines[curr[0]][i]+result[curr[0]];
                if(lines[curr[0]][i]>0 && result[i]>cost){
                    result[i] = cost;
                    pq.offer(new int[]{i,cost});
                } 
            }    
        }
        return result;
    }
} 

dijkstra 알고리즘을 이용하여 시작 위치에서 각 지점까지 가는데 드는 최소 비용을 계산하였습니다.

dijkstra 알고리즘은 비용이 최소인 노선을 사용하여 지점을 방문한 후 지점에 도착하는데 드는 비용을 저장함으로서 구현할 수 있습니다.

S, A, B에서 시작하는 dijkstra 계산결과를 저장한 후, 최소 값이 되는 k를 찾아 비용을 반환합니다.