본문 바로가기

[Algorithms]/[Problems]

BOJ. 1238번. 파티

728x90

 

이 문제는 다익스트라 알고리즘을 뒤집어 붙이는 문제이다. 처음에 리스트로 맵을 만든 다음, 해당 맵을 기준으로 두가지 다익스트라 알고리즘(하나는 정방향, 하나는 역방향)을 만들려고 했다가, 데이터 자체를 반전시키는 편이 훨씬 간편하다는 것을 깨닫고 선회했다.

문제 풀이는 간단하다.
1. 정방향에 따른 방문체크배열, 인접리스트, 최소비용행렬을 선언한다.
2. 역방향도 마찬가지로 만들어 준다.
3. 정방향과 역방향 각각에 따른 최소비용행렬을 둘다 계산한 다음, 정향향,역방향 비용의 합 중 최대비용인 놈을 찾으면 끝

www.acmicpc.net/problem/1238

 

1238번: 파티

첫째 줄에 N(1 ≤ N ≤ 1,000), M(1 ≤ M ≤ 10,000), X가 공백으로 구분되어 입력된다. 두 번째 줄부터 M+1번째 줄까지 i번째 도로의 시작점, 끝점, 그리고 이 도로를 지나는데 필요한 소요시간 Ti가 들어

www.acmicpc.net

package week_11;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.PriorityQueue;
import java.util.StringTokenizer;
 
public class Day3BOJ1238 {
 
    private static final int INF = Integer.MAX_VALUE>>1;
    private static int N, M, X;
    private static List<List<City>> list, returnList;
    private static int[] dist, returnDist;
    private static boolean[] visited, returnVisited;
 
    static class City implements Comparable<City> {
        int num,ddist;
        public City(int num, int ddist) {
            this.num = num;
            this.ddist = ddist;
        }
        public int compareTo(City o) {
            return this.ddist - o.ddist;
        }
    }
 
    public static void main(String[] args) throws IOException {
    	BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());
        N = Integer.parseInt(st.nextToken());
        M = Integer.parseInt(st.nextToken());
        X = Integer.parseInt(st.nextToken());
 
        list = new ArrayList<>(); // 가는용
        returnList = new ArrayList<>(); // 오는용
        
        for (int i = 0; i <= N; i++) {
            list.add(new ArrayList<>());
            returnList.add(new ArrayList<>());
        }
 
        // 가는놈
        dist = new int[N + 1];
        Arrays.fill(dist, INF);
        // 오는놈
        returnDist = new int[N + 1];
        Arrays.fill(returnDist, INF);
        // 방문체크
        visited = new boolean[N + 1];
        returnVisited = new boolean[N + 1];
 
        for (int i = 1; i <= M; i++) {
            st = new StringTokenizer(br.readLine());
            int from = Integer.parseInt(st.nextToken());
            int to = Integer.parseInt(st.nextToken());
            int time = Integer.parseInt(st.nextToken());
            list.get(from).add(new City(to, time));
            returnList.get(to).add(new City(from, time));
        }
 
        dijkstra(visited,dist,list);
        dijkstra(returnVisited,returnDist,returnList);
       
        int ans = 0;
        for (int i = 1; i <= N; i++) {
            ans = Math.max(ans, dist[i]+returnDist[i]);
        }
        System.out.println(ans);
    }
 
    private static void dijkstra(boolean[] visited, int[] distance, List<List<City>> list) {
        PriorityQueue<City> pq = new PriorityQueue<>();
        pq.add(new City(X, 0));
        
        distance[X] = 0;
 
        while (!pq.isEmpty()) {
            int idx = pq.poll().num;
 
            if (visited[idx]) continue;
            visited[idx] = true;
 
            for (City node : list.get(idx)) {
                if (distance[node.num] > distance[idx] + node.ddist) {
                    distance[node.num] = distance[idx] + node.ddist;
                    pq.add(new City(node.num, distance[node.num]));
                }
            }
        }
    }
 
}

 

728x90

'[Algorithms] > [Problems]' 카테고리의 다른 글

BOJ. 11437번. LCA  (0) 2021.04.10
BOJ. 11657번. 타임머신  (0) 2021.04.09
BOJ. 11780번. 플로이드 2  (0) 2021.03.30
BOJ. 20061번. 모노미노도미노 2  (0) 2021.03.29
BOJ. 1600번. 말이 되고픈 원숭이  (0) 2021.03.24