[알고리즘] 백준 11779

shininghyunho·2022년 2월 22일
0

문제

다익스트라를 구현해보고 경로도 같이 출력해보는 문제다.
링크

최단 경로를 어떤식으로 추적할수있을까 고민하다
다른 코드를 참고해 최단 경로를 저장하는 법을 생각했다.

경로추적

now -> next로 접근할때
route[next]=now 로 저장하며 추적한다.
(경로가 여러개일 경우 계속 업데이트를 하므로 마지막 경로가 저장됨)

예제 그림

Code

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;

class B11779_SOL{
    private static int n,m,from,to;
    private static final int INF=987654321;
    private static List<List<Node>> graph=new ArrayList<>();
    private static int[] dist,route;
    class Node{
        // a->b , d
        int p,d;

        public Node(int p, int d) {
            this.p = p;
            this.d = d;
        }
    }
    public void input() throws IOException{
        BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer stk;
        n=Integer.parseInt(br.readLine());
        m=Integer.parseInt(br.readLine());
        for(int i=0;i<n+1;i++) graph.add(new ArrayList<>());
        for(int i=0;i<m;i++){
            stk=new StringTokenizer(br.readLine());
            int a=Integer.parseInt(stk.nextToken());
            int b=Integer.parseInt(stk.nextToken());
            int d=Integer.parseInt(stk.nextToken());
            graph.get(a).add(new Node(b,d));
        }
        stk=new StringTokenizer(br.readLine());
        from=Integer.parseInt(stk.nextToken());
        to=Integer.parseInt(stk.nextToken());
    }
    public void solve(){
        dist=new int[n+1];
        route=new int[n+1];
        dijkstra(from,dist,graph);
        print();
    }
    private void dijkstra(int start,int[] dist,List<List<Node>> graph){
        for(int i=0;i<n+1;i++) dist[i]=INF;
        dist[start]=0;
        route[start]=-1;
        PriorityQueue<Node> pq=new PriorityQueue<>((a,b)->{return a.d-b.d;});
        pq.add(new Node(start,0));
        while(!pq.isEmpty()){
            Node now=pq.poll();
            if(dist[now.p]<now.d) continue;
            for(Node next:graph.get(now.p)){
                int newDist=dist[now.p]+next.d;
                if(newDist<dist[next.p]){
                    dist[next.p]=newDist;
                    route[next.p]=now.p;
                    pq.add(new Node(next.p,newDist));
                }
            }
        }
    }
    private void print(){
        Stack<Integer> st=new Stack<>();
        int now=to;
        while(now!=-1){
            st.add(now);
            now=route[now];
        }
        StringBuilder sb=new StringBuilder();
        sb.append(dist[to]).append("\n");
        sb.append(st.size()).append("\n");
        while(!st.isEmpty()) sb.append(st.pop()).append(" ");
        System.out.println(sb);
    }

}
public class Main {
    public static void main(String[] args) throws IOException{
        B11779_SOL sol=new B11779_SOL();
        sol.input();
        sol.solve();
    }
}
profile
shining itself

0개의 댓글

관련 채용 정보