코테/코드트리
[코드트리/NOVICE HIGH] 네비게이션 (JAVA)
imname1am
2023. 9. 22. 12:54
반응형
🔺 문제
코드트리 | 코딩테스트 준비를 위한 알고리즘 정석
국가대표가 만든 코딩 공부의 가이드북 코딩 왕초보부터 꿈의 직장 코테 합격까지, 국가대표가 엄선한 커리큘럼으로 준비해보세요.
www.codetree.ai
🔺 코드
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
import java.util.*;
import java.io.*;
public class Main {
static int INF = Integer.MAX_VALUE;
static int V, E, start;
static ArrayList<Node>[] A;
static int[] dist; // 최단거리 배열
static PriorityQueue<Node> pq = new PriorityQueue<>(); // 우선순위 큐
static StringBuilder sb = new StringBuilder();
static StringBuilder tmpSb = new StringBuilder();
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
V = Integer.parseInt(st.nextToken()); // 정점
E = Integer.parseInt(st.nextToken()); // 간선
start = Integer.parseInt(br.readLine());
// 초기화
A = new ArrayList[V + 1];
for(int i = 1 ; i <= V ; i++) {
A[i] = new ArrayList<>();
}
dist = new int[V + 1];
Arrays.fill(dist, INF);
dist[start] = 0;
// 간선 정보 입력 받기
for(int i = 0 ; i < E ; i++) {
st = new StringTokenizer(br.readLine(), " ");
int u = Integer.parseInt(st.nextToken());
int v = Integer.parseInt(st.nextToken());
int w = Integer.parseInt(st.nextToken());
A[u].add(new Node(v, w));
}
dijkstra(start);
for(int i = 1 ; i <= V ; i++) {
sb.append(dist[i] == INF ? "INF" : dist[i]).append("\n");
}
System.out.println(sb);
System.out.println(tmpSb);
}
private static void dijkstra(int num) {
pq.add(new Node(num, 0));
while(!pq.isEmpty()) {
Node now = pq.poll();
for(Node next : A[now.e]) {
if(dist[next.e] > dist[now.e] + next.v) {
dist[next.e] = dist[now.e] + next.v;
pq.add(new Node(next.e, dist[next.e]));
for(int i = 1 ; i < dist.length ; i++) {
tmpSb.append(dist[i] == INF ? "INF" : dist[i]).append(" ");
}
tmpSb.append("\n");
}
}
}
}
}
class Node implements Comparable<Node> {
int e, v;
public Node(int e, int v) {
this.e = e; this.v = v;
}
@Override
public int compareTo(Node node) {
return this.v - node.v;
}
}
|
cs |
📍 입력값
1
2
3
4
5
6
7
8
9
10
11
12
|
6 10
1
1 2 2
1 3 5
1 4 1
2 3 3
4 3 3
4 5 1
3 6 5
3 5 1
5 6 2
2 4 2
|
cs |
📍 최단 거리 배열 업데이트 결과 출력용
💬 느낀 점
다익스트라 복습....
얼마 전 코테에서 보고 못 풀어서 아쉬웠던....ㅠ
1회독 | 2회독 | 3회독 | 4회독 | 5회독 |
V |
(참고)
[백준/JAVA] 1753번: 최단경로
🔺 문제 1753번: 최단경로 첫째 줄에 정점의 개수 V와 간선의 개수 E가 주어진다. (1 ≤ V ≤ 20,000, 1 ≤ E ≤ 300,000) 모든 정점에는 1부터 V까지 번호가 매겨져 있다고 가정한다. 둘째 줄에는 시작 정
bono039.tistory.com
반응형