반응형
01-27 05:03
- Today
- Total
Link
개발하는 고라니
[Programmers] 가장 먼 노드 본문
반응형
[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