코드와이
[SW Expert Academy] 1238. [S/W 문제해결 기본] 10일차 - Contact 본문
문제링크
package D4;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.PriorityQueue;
import java.util.StringTokenizer;
public class contact {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringBuilder sb = new StringBuilder();
StringTokenizer st;
for(int tc = 1; tc <= 10 ; tc++) {
sb.append("#").append(tc).append(" ");
st = new StringTokenizer(br.readLine());
int n = Integer.parseInt(st.nextToken());
int start = Integer.parseInt(st.nextToken());
int[][] arr = new int[n+1][n+1];
st = new StringTokenizer(br.readLine());
for(int i = 0 ; i < n/2 ; i++) {
int a = Integer.parseInt(st.nextToken());
int b = Integer.parseInt(st.nextToken());
arr[a][b] = 1;
}
int ans = start;
PriorityQueue<Integer> queue = new PriorityQueue<Integer>();
boolean[] visited = new boolean[n+1];
ArrayList<Integer> list = new ArrayList<Integer>();
queue.add(start);
visited[start] = true;
int idx = 0;
while(true) {
boolean flag = false;
while(!queue.isEmpty()) {
list.add(queue.poll());
}
int l = list.size();
for(int j = idx ; j < l ; j++) {
for(int i = 1 ; i <= n ; i++) {
if(arr[list.get(j)][i] == 1 && !visited[i]) {
flag = true;
queue.add(i);
visited[i] = true;
}
}
}
idx = l;
if(!flag) {
ans = list.get(list.size()-1);
break;
}
}
sb.append(ans).append("\n");
}
sb.setLength(sb.length()-1);
System.out.println(sb);
}
}
'SW_Expert' 카테고리의 다른 글
[SW Expert Academy] 3347. 올림픽 종목 투표 (0) | 2021.03.12 |
---|---|
[SW Expert Academy] 7854. 최약수 (0) | 2021.03.11 |
[SW Expert Academy] 6719. 성수의 프로그래밍 강좌 시청 (0) | 2021.03.10 |
[SW Expert Academy] 1868. 파핑파핑 지뢰찾기 (0) | 2021.03.09 |
[SW Expert Academy] 1249. [S/W 문제해결 응용] 4일차 - 보급로 (0) | 2021.03.03 |