[BOJ/백준] 6118 숨바꼭질 (S1)

2024. 7. 8. 14:11· Algorithm PS/Baekjoon Online Judge
목차
  1. 문제
  2. 풀이
  3. Code

문제

https://www.acmicpc.net/problem/6118

풀이

Code

import java.io.*;
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.StringTokenizer;

public class Main {

    static ArrayList<Integer>[] adjList;  // 인접 리스트를 저장할 배열
    static int N, M;
    static int[] distance;  // 1번 헛간부터 각 헛간까지의 거리를 저장할 배열

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        StringTokenizer st;

        st = new StringTokenizer(br.readLine());
        N = Integer.parseInt(st.nextToken());  // 헛간의 수(vertex)
        M = Integer.parseInt(st.nextToken());  // 양방향 길의 수(edge)

        adjList = new ArrayList[N+1];  // 각 헛간의 인접 리스트 초기화
        for (int i = 0; i < adjList.length; i++) {
            adjList[i] = new ArrayList<>();  // 인접 리스트 초기화
        }

        distance = new int[N + 1];
        Arrays.fill(distance, -1);

        for (int i = 0; i < M; i++) {
            st = new StringTokenizer(br.readLine());
            int A_i = Integer.parseInt(st.nextToken());
            int B_i = Integer.parseInt(st.nextToken());
            adjList[A_i].add(B_i);  // A_i와 B_i를 서로 연결(무방향이니까 양방향으로 연결)
            adjList[B_i].add(A_i);
        }

        bfs(1);

        int maxDistance = 0;  // 최대 거리
        int maxDisNum = 0;  // 최대 거리에 있는 헛간의 번호
        int cnt = 0;  // 최대 거리와 동일한 거리를 갖는 헛간의 개수

        for (int i = 1; i <= N; i++) {
            // 현재 헛간[i]의 거리가 최대 거리보다 큰 경우
            if (distance[i] > maxDistance) {
                maxDistance = distance[i];  // 최대 거리를 현재 헛간[i]의 거리로 갱신
                maxDisNum = i;  // 최대 거리를 갖는 헛간의 번호를 현재 헛간[i]로 갱신
                cnt = 1;  // 최대 거리를 갖는 헛간의 개수를 1로 초기화

            // 현재 헛간[i]의 거리가 최대 거리와 같은 경우
            } else if (distance[i] == maxDistance) {
                // 헛간 번호가 현재 저장된 헛간 번호보다 작은 경우
                if (i < maxDisNum) {
                    maxDisNum = i;  // 헛간 번호를 더 작은 번호로 갱신 (만약 거리가 같은 헛간이 여러개면 가장 작은 헛간 번호를 출력한다)
                }
                cnt++;  // 그리고 최대 거리를 갖는 헛간의 개수를 증가
            }
        }
        bw.write(maxDisNum + " " + maxDistance + " " + cnt);
        bw.flush();
        bw.close();
    }

    // BFS로 1번 헛간부터 각 헛간까지의 최단 거리를 계산(일반적인 BFS 연산)
    private static void bfs(int start) {
        ArrayDeque<Integer> queue = new ArrayDeque<>();
        queue.add(start);  // 출발 지점을 추가
        distance[start] = 0;  // 출발 지점의 거리는 0

        while (!queue.isEmpty()) {
            int now = queue.poll();  // 꺼내고,

            for (int next : adjList[now]) {
                if (distance[next] != -1) continue;  // 다음 노드가 이미 방문한 곳이면 pass
                // 방문하지 않은 헛간이면?
                queue.add(next);
                distance[next] = distance[now] + 1;
            }
        }
    }
}

if (i < maxDisNum) { maxDistance = i; } 에서 정상적으로 "맞았습니다"가 떴었는데 복습하면서 다시 보니 if (i < maxDisNum) { maxDisNum = i; } 이게 맞아서 수정함. (왜 되는거지..?)

728x90

'Algorithm PS > Baekjoon Online Judge' 카테고리의 다른 글

[BOJ/백준] 1926 그림 (S1)  (0) 2024.07.14
[BOJ/백준] 2667 단지번호붙이기 (S1)  (0) 2024.07.13
[BOJ/백준] 2260 회장뽑기 (G5)  (0) 2024.07.06
[BOJ/백준] 5567 결혼식 (S2)  (0) 2024.07.05
[BOJ/백준] 11726 2×n 타일링 (S3)  (0) 2024.07.03
  1. 문제
  2. 풀이
  3. Code
'Algorithm PS/Baekjoon Online Judge' 카테고리의 다른 글
  • [BOJ/백준] 1926 그림 (S1)
  • [BOJ/백준] 2667 단지번호붙이기 (S1)
  • [BOJ/백준] 2260 회장뽑기 (G5)
  • [BOJ/백준] 5567 결혼식 (S2)
kyung.Kh
kyung.Kh
kyung.Kh
Dev..studynote
kyung.Kh
전체
오늘
어제
05-29 15:13
  • 분류 전체보기 (68)
    • Algorithm PS (29)
      • Baekjoon Online Judge (29)
      • Programmers (0)
    • Computer Science (4)
      • Databse (0)
      • Operating System (0)
      • Computer Network (0)
      • Computer Architecture (0)
      • Algorithm (4)
    • Spring (29)
      • Spring Boot (1)
      • 스프링 핵심 원리 - 기본편(인프런 김영한) (7)
      • Java (1)
      • 자바 ORM 표준 JPA 프로그래밍 (20)
    • Project (2)
      • 문제 & 해결 (2)
    • Book (3)
      • 객체지향의 사실과 오해 (3)
    • 우하한테크코스 (1)
      • precourse (1)

최근 글

인기 글

블로그 메뉴

    태그

    • 구현
    • 재귀
    • dfs
    • 백준
    • 알고리즘
    • 스프링 기본편
    • Spring
    • 객체지향
    • JPA
    • BFS
    • 스프링
    • 인프런
    • 스프링부트
    • Graph
    • springboot
    • 스프링 김영한
    • DP
    • 해시를 사용한 집합과 맵
    • Union-Find
    • 그리디
    hELLO · Designed By 정상우.v4.2.2
    kyung.Kh
    [BOJ/백준] 6118 숨바꼭질 (S1)
    상단으로

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.