[백준 / 골드4] 4803 트리 (Java)

wannabeking·2022년 12월 5일
0

코딩테스트

목록 보기
137/155

문제 보기



사용한 것

  • 트리의 root 부터 시작하여 순회하기 위한 DFS


풀이 방법

  • 1번 노드부터 n번 노드까지 for 문을 돌면서
    • 이미 방문한 노드면 continue
    • 방문하지 않은 노드면 ct 증가, DFS
      • DFS는 방문 노드마다 visited를 true
      • 현재 노드의 자식이 이미 visited true 라면 사이클이므로 return false


코드

public class Main {

    private static BufferedReader br;
    private static StringTokenizer st;
    private static int n;
    private static int m;
    private static List<List<Integer>> tree;
    private static boolean[] visited;

    public static void main(String[] args) throws IOException {
        br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();

        int t = 1;
        while (init()) {
            int ct = 0;
            for (int i = 1; i <= n; i++) {
                if (visited[i]) {
                    continue;
                }

                if (dfs(-1, i)) {
                    ct++;
                }
            }

            sb.append(getResult(t, ct))
                .append(lineSeparator());

            t++;
        }

        System.out.println(sb);

        br.close();
    }

    private static boolean init() throws IOException {
        st = new StringTokenizer(br.readLine());
        n = Integer.parseInt(st.nextToken());
        m = Integer.parseInt(st.nextToken());
        // "0 0" 입력 시 종료
        if (n == 0 && m == 0) {
            return false;
        }
        // tree, visited 초기화
        tree = new ArrayList<>();
        for (int i = 0; i <= n; i++) {
            tree.add(new ArrayList<>());
        }
        visited = new boolean[n + 1];
        // 간선 입력
        for (int i = 0; i < m; i++) {
            st = new StringTokenizer(br.readLine());
            int v1 = Integer.parseInt(st.nextToken());
            int v2 = Integer.parseInt(st.nextToken());
            tree.get(v1).add(v2);
            tree.get(v2).add(v1);
        }
        return true;
    }

    private static boolean dfs(int parent, int v) {
        visited[v] = true;
        List<Integer> children = tree.get(v);
        for (int child : children) {
            if (child == parent) {
                continue;
            }
            if (visited[child] || !dfs(v, child)) {
                return false;
            }
        }
        return true;
    }

    private static String getResult(int t, int ct) {
        StringBuilder sb = new StringBuilder();
        sb.append("Case ").append(t).append(": ");
        if (ct == 0) {
            sb.append("No trees.");
        } else if (ct == 1) {
            sb.append("There is one tree.");
        } else {
            sb.append("A forest of ").append(ct).append(" trees.");
        }
        return sb.toString();
    }
}


profile
내일은 개발왕 😎

0개의 댓글