[백준] 2606 바이러스(Java)

수경·2023년 4월 17일
0

problem solving

목록 보기
137/174

백준 - 2606 바이러스

풀이

DFS
재귀에 들어갈 때마다 count 증가시켜서 재귀 회수 세기
count -> 전역변수로 설정

코드

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {
    static int count = 0;
    private static void dfs(int[][] graph, boolean[] visited, int vertex, int start) {
        visited[start] = true;
        count++;
        for (int i = 1; i < vertex + 1; i++) {
            if (graph[start][i] == 1 && !visited[i]) {
                dfs(graph, visited, vertex, i);
            }
        }
    }
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int vertex = Integer.parseInt(br.readLine());
        int line = Integer.parseInt(br.readLine());

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

        for (int i = 0; i < line; i++) {
            StringTokenizer token = new StringTokenizer(br.readLine());
            int to = Integer.parseInt(token.nextToken());
            int from = Integer.parseInt(token.nextToken());
            graph[to][from] = graph[from][to] = 1;
        }

        dfs(graph, visited, vertex, 1);
        System.out.println(count - 1);
    }
}
profile
어쩌다보니 tmi뿐인 블로그😎

0개의 댓글