일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 백준
- 경제
- 코딩테스트
- 코테
- 테마주
- 자바
- boj
- 주식 상한가
- 급등 이유
- 상한가
- 손경제 요약
- 급등주
- 주식 분석
- 상한가 분석
- Programmers
- 파이썬
- 경제뉴스 요약
- 손경제
- Python
- 상한가 이유
- 경제뉴스
- 이진우의 손에 잡히는 경제
- 급등주 분석
- 손에 잡히는 경제 요약
- java
- 프로그래머스
- 이진우
- 주식
- 손에 잡히는 경제
- 알고리즘
- Today
- Total
Completion over Perfection
백준 1976 - 여행가자 (JAVA) 본문
백준 1976 - 여행가자 (JAVA)
유니언파인드로 풀려고 했는데, 이게 유니언파인드로 푼게 맞는지 모르겠네요.
유니언파인드에 대한 대략적인 개념만 읽고 푼 코드라서..
이렇게 푸는 사람도 있구나~ 정도로 참고만 해주시면 좋을 것 같습니다.
푼 방법은 아래와 같습니다.
[코드를 짠 대략적인 흐름]
- map 2차원 배열에 0과 1로 제공되는 연결정보를 그대로 저장해준다.
- map배열에서 1일 경우에는 서로 여행갈 수 있는 노선이 있다는 뜻이며(78행),
info배열 안의 값을 비교했을 때 더 작은 값으로 업데이트 해준다. (81행~85행)
- 최종적으로 여행지가 연결이 되어있는지에 대한 부분은 마지막에 제공되는 여행계획 순서 부분을 배열로 받은 뒤에
출발지와 목적지로 나누고, 출발지와 목적지에 대한 info값이 동일하다면 여행갈 수 있는 것이라고 판단하였습니다. (61행 ~ 70행)
- find 함수를 두번 돌려주었는데, 이유는 아래의 참고반례 사례 때문입니다.
- 예를들어 총 5개의 여행지가 존재하고, 1-4 / 2-3 / 3-4 가 연결되어있다고 가정했을 때, 1-2-3의 순서대로 여행을 한다고 하면 YES가 나오는것이 맞습니다. (모든 여행지가 연결이 되어 있으므로)
하지만 코드를 잘못짰다면 NO가 출력될 것입니다. 잘못 출력될 수 있는 이유는 저의 코드 기준으로 3-4 연결부분에 대한 info배열 업데이트가 1-4 연결부분 업데이트보다 늦어지기 때문입니다. (코드 짜다 보시면 이해가 될거에요)
[참고반례]
아래 케이스를 넣었을 때 YES가 출력되어야 한다.
5
3
0 0 0 1 0
0 0 1 0 0
0 1 0 1 0
1 0 1 0 0
0 0 0 0 0
1 2 3
정답 : YES
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
87
88
89
90
91
92
93
94
95
96
|
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class Travel_Backjoon {
static int N, M; // N = 도시의 수, M = 여행계획에 속한 도시들의 수
static int [][] map; // 도시가 연결되어 있는지를 저장할 배열
static int [] info; // 유니온파인드를 위한 배열
static boolean [][] check;
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()); // 3 도시의갯수 : 3
st = new StringTokenizer(br.readLine());
M = Integer.parseInt(st.nextToken()); // 3 여행할 도시의 수 : 3
info = new int [N+1];
check = new boolean[N+1][N+1];
for (int i=1; i<=N; i++){
info[i] = i; // 배열 초기화, 인덱스 번호에 그 수가 들어가도록 세팅
}
map = new int[N+1][N+1];
for (int i=1; i<=N; i++){
st = new StringTokenizer(br.readLine()); // 0 1 0
for (int j=1; j<=N; j++){
map[i][j] = Integer.parseInt(st.nextToken());
}
}
for (int i=1; i<=N; i++){
find(i);
}
check = new boolean[N+1][N+1];
for (int i=1; i<=N; i++){
find(i);
}
int [] travelplan = new int [M+1];
st = new StringTokenizer(br.readLine()); // 1 2 3
for (int i=1; i<=M; i++){
travelplan[i] = Integer.parseInt(st.nextToken()); // travelplan[1] = 1
}
for (int i=1; i<=M-1; i++){
int from = travelplan[i]; // 1 2
int to = travelplan[i+1]; // 2 3
if (info[from] != info[to]){
System.out.println("NO");
return;
}
}
System.out.println("YES");
}
public static int find(int x){
for (int i=1; i<=N; i++) {
if (x!=i && map[x][i] == 1 && !check[x][i]) { // map[2][1] == 1
check[x][i] = true;
check[i][x] = true;
if (info[i] > info[x]){
info[i] = info[x];
}else{
info[x] = info[i];
}
}
}
return info[x];
}
}
|
cs |
'앨고리듬 알고리즘' 카테고리의 다른 글
백준 10026 - 적록색약 (JAVA 자바) (0) | 2021.01.28 |
---|---|
백준 2468 - 안전 영역 (JAVA 자바) (0) | 2021.01.28 |
백준 2252 - 줄 세우기 (JAVA 자바) (0) | 2020.12.02 |
백준 2075 - N번째 큰 수 (JAVA 자바) (0) | 2020.11.30 |
백준 4963 - 섬의 개수 (JAVA 자바) (0) | 2020.11.25 |