Playground/자바문제집
[백준] 1260번
미숫가루설탕많이
2023. 5. 15. 00:02
bfs는 queue, dfs는 재귀를 활용했다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;
public class Main {
static int node, line, start;
static int[][] arr;
static boolean[] visited;
static StringBuilder sb = new StringBuilder();
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
node = Integer.parseInt(st.nextToken()); // 정점의 개수
line = Integer.parseInt(st.nextToken()); // 간선의 개수
start = Integer.parseInt(st.nextToken()); // 탐색을 시작할 정점의 번호
arr = new int[node + 1][node + 1];
visited = new boolean[node + 1];
for (int i = 0; i < line; i++) {
StringTokenizer edge = new StringTokenizer(br.readLine());
int x = Integer.parseInt(edge.nextToken());
int y = Integer.parseInt(edge.nextToken());
arr[x][y] = arr[y][x] = 1;
}
dfs(start);
sb.append("\n");
visited = new boolean[node + 1];
bfs(start);
System.out.println(sb);
}
public static void bfs(int v) {
Queue<Integer> que = new LinkedList<>();
que.add(v);
visited[v] = true;
while (!que.isEmpty()) {
v = que.poll(); // 큐에서 노드를 꺼낸다
sb.append(v).append(" ");
for (int i = 1; i <= node; i++) {
// 해당 노드와 인접한 노드들 중 아직 방문하지 않은 노드를 큐에 추가하고 방문 처리한다
if (arr[v][i] == 1 && !visited[i]) {
que.add(i);
visited[i] = true;
}
}
}
}
public static void dfs(int v) {
visited[v] = true;
sb.append(v).append(" ");
for (int i = 0; i <= node; i++) {
// 해당 노드와 인접한 노드들 중 아직 방문하지 않은 노드들을 재귀 호출한다
if (arr[v][i] == 1 && !visited[i]) {
dfs(i);
}
}
}
}