반응형
12-24 00:25
Today
Total
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
관리 메뉴

개발하는 고라니

[Programmers] 가장 먼 노드 본문

Programming/프로그래머스

[Programmers] 가장 먼 노드

조용한고라니 2021. 3. 28. 16:33
반응형
 

코딩테스트 연습 - 가장 먼 노드

6 [[3, 6], [4, 3], [3, 2], [1, 3], [1, 2], [2, 4], [5, 2]] 3

programmers.co.kr


[Dijkstra]

1번 정점에서 모든 정점까지의 최단 거리를 구해 dist[ ]에 저장 후, 1번 정점부터 n번 정점까지 dist[i]를 돌면서 dist[i]가 max인 곳의 정점 개수를 카운팅 한다.

# Code </>

import java.util.ArrayList;
import java.util.List;
import java.util.PriorityQueue;
import java.util.Queue;

class Solution {

    static class Edge{
        int tg, d;
        public Edge(int target, int dist){
            tg=target;
            d=dist;
        }
    }

    static final int INF = 1000000000;
    static List<Integer>[] list = new ArrayList[20001];
    static int[] dist = new int[20001];

    static void Dijkstra(){
        Queue<Edge> Q = new PriorityQueue<>((a, b) -> a.d - b.d);
        dist[1] = 0;
        Q.add(new Edge(1, 0));

        while(!Q.isEmpty()){
            Edge e = Q.poll();
            int cur = e.tg;
            int d = e.d;

            if(dist[cur] < d) continue;

            for(int next:list[cur])
                if(dist[next] > d + 1){
                    dist[next] = d + 1;
                    Q.add(new Edge(next, d + 1));
                }
        }
    }

    public int solution(int n, int[][] edge) {

        for(int i=1; i<=n; i++){
            list[i] = new ArrayList<>();
            dist[i] = INF;
        }

        for(int i=0; i<edge.length; i++){
            list[edge[i][0]].add(edge[i][1]);
            list[edge[i][1]].add(edge[i][0]);
        }

        Dijkstra();

        int answer = 0, max = 0;

        for(int i=1; i<=n; i++)
            if(dist[i] > max){
                answer = 1;
                max = dist[i];
            }
            else if(max == dist[i])
                answer++;

        return answer;
    }
}

public class Main {
    public static void main(String[] args) {
        Solution sol = new Solution();

        int n = 6;
        int[][] edge = {{3, 6}, {4, 3}, {3, 2}, {1, 3}, {1, 2}, {2, 4}, {5, 2}};

        System.out.println(sol.solution(n, edge));
    }
}
반응형

'Programming > 프로그래머스' 카테고리의 다른 글

[Programmers] 124 나라의 숫자  (0) 2021.05.10
[Programmers] 순위  (0) 2021.03.28
[Programmers] 문자열 내 마음대로 정렬하기  (0) 2021.03.17
[Programmers] 지형 이동  (0) 2021.03.10
[Programmers] 섬 연결하기  (0) 2021.03.10
Comments