[백준] 1260 DFS와 BFS(Java)

수경·2023년 4월 17일
0

problem solving

목록 보기
135/174

백준 - 1260 DFS와 BFS

코드

import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class Main {
    private static void dfs(int[][] graph, boolean[] visited, int vertex, int start) {
        visited[start] = true;
        System.out.print(start + " ");
        for (int i = 1; i < vertex + 1; i++) {
            if (graph[start][i] == 1 && !visited[i]) {
                dfs(graph, visited, vertex, i);
            }
        }
    }

    private static void bfs(int[][] graph, boolean[] visited, int vertex, int start) {
        Queue<Integer> queue = new LinkedList<>();
        queue.add(start);
        visited[start] = true;
        while (!queue.isEmpty()) {
            start = queue.poll();
            System.out.print(start + " ");
            for (int i = 1; i < vertex + 1; i++) {
                if (graph[start][i] == 1 && !visited[i]) {
                    queue.add(i);
                    visited[i] = true;
                }
            }
        }
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        String[] input = sc.nextLine().split(" ");
        int vertex = Integer.parseInt(input[0]);
        int line = Integer.parseInt(input[1]);
        int start = Integer.parseInt(input[2]);

        boolean[] visited = new boolean[vertex + 1];
        int[][] graph = new int[vertex + 1][vertex + 1];


        for (int i = 0; i < line; i++) {
            String[] connect = sc.nextLine().split(" ");
            int to = Integer.parseInt(connect[0]);
            int from = Integer.parseInt(connect[1]);
            graph[to][from] = graph[from][to] = 1;
        }

        dfs(graph, visited, vertex, start);
        System.out.println();
        visited = new boolean[vertex + 1];
        bfs(graph, visited, vertex, start);
    }
}
profile
어쩌다보니 tmi뿐인 블로그😎

0개의 댓글