๐Ÿ“š Study/Baekjoon

[Silver I] 1389 - ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™

์œฐ๊ฐฑ 2025. 4. 19. 01:57

๋ฌธ์ œ

์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™์— ์˜ํ•˜๋ฉด ์ง€๊ตฌ์— ์žˆ๋Š” ๋ชจ๋“  ์‚ฌ๋žŒ๋“ค์€ ์ตœ๋Œ€ 6๋‹จ๊ณ„ ์ด๋‚ด์—์„œ ์„œ๋กœ ์•„๋Š” ์‚ฌ๋žŒ์œผ๋กœ ์—ฐ๊ฒฐ๋  ์ˆ˜ ์žˆ๋‹ค. ์ผ€๋นˆ ๋ฒ ์ด์ปจ ๊ฒŒ์ž„์€ ์ž„์˜์˜ ๋‘ ์‚ฌ๋žŒ์ด ์ตœ์†Œ ๋ช‡ ๋‹จ๊ณ„ ๋งŒ์— ์ด์–ด์งˆ ์ˆ˜ ์žˆ๋Š”์ง€ ๊ณ„์‚ฐํ•˜๋Š” ๊ฒŒ์ž„์ด๋‹ค.

์˜ˆ๋ฅผ ๋“ค๋ฉด, ์ „ํ˜€ ์ƒ๊ด€์—†์„ ๊ฒƒ ๊ฐ™์€ ์ธํ•˜๋Œ€ํ•™๊ต์˜ ์ด๊ฐ•ํ˜ธ์™€ ์„œ๊ฐ•๋Œ€ํ•™๊ต์˜ ๋ฏผ์„ธํฌ๋Š” ๋ช‡ ๋‹จ๊ณ„๋งŒ์— ์ด์–ด์งˆ ์ˆ˜ ์žˆ์„๊นŒ?

์ฒœ๋ฏผํ˜ธ๋Š” ์ด๊ฐ•ํ˜ธ์™€ ๊ฐ™์€ ํ•™๊ต์— ๋‹ค๋‹ˆ๋Š” ์‚ฌ์ด์ด๋‹ค. ์ฒœ๋ฏผํ˜ธ์™€ ์ตœ๋ฐฑ์ค€์€ Baekjoon Online Judge๋ฅผ ํ†ตํ•ด ์•Œ๊ฒŒ ๋˜์—ˆ๋‹ค. ์ตœ๋ฐฑ์ค€๊ณผ ๊น€์„ ์˜์€ ๊ฐ™์ด Startlink๋ฅผ ์ฐฝ์—…ํ–ˆ๋‹ค. ๊น€์„ ์˜๊ณผ ๊น€๋„ํ˜„์€ ๊ฐ™์€ ํ•™๊ต ๋™์•„๋ฆฌ ์†Œ์†์ด๋‹ค. ๊น€๋„ํ˜„๊ณผ ๋ฏผ์„ธํฌ๋Š” ๊ฐ™์€ ํ•™๊ต์— ๋‹ค๋‹ˆ๋Š” ์‚ฌ์ด๋กœ ์„œ๋กœ ์•Œ๊ณ  ์žˆ๋‹ค. ์ฆ‰, ์ด๊ฐ•ํ˜ธ-์ฒœ๋ฏผํ˜ธ-์ตœ๋ฐฑ์ค€-๊น€์„ ์˜-๊น€๋„ํ˜„-๋ฏผ์„ธํฌ ์™€ ๊ฐ™์ด 5๋‹จ๊ณ„๋งŒ ๊ฑฐ์น˜๋ฉด ๋œ๋‹ค.

์ผ€๋นˆ ๋ฒ ์ด์ปจ์€ ๋ฏธ๊ตญ ํ—๋ฆฌ์šฐ๋“œ ์˜ํ™”๋ฐฐ์šฐ๋“ค ๋ผ๋ฆฌ ์ผ€๋นˆ ๋ฒ ์ด์ปจ ๊ฒŒ์ž„์„ ํ–ˆ์„๋•Œ ๋‚˜์˜ค๋Š” ๋‹จ๊ณ„์˜ ์ด ํ•ฉ์ด ๊ฐ€์žฅ ์ ์€ ์‚ฌ๋žŒ์ด๋ผ๊ณ  ํ•œ๋‹ค.

์˜ค๋Š˜์€ Baekjoon Online Judge์˜ ์œ ์ € ์ค‘์—์„œ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์„ ์ฐพ์œผ๋ ค๊ณ  ํ•œ๋‹ค. ์ผ€๋นˆ ๋ฒ ์ด์ปจ ์ˆ˜๋Š” ๋ชจ๋“  ์‚ฌ๋žŒ๊ณผ ์ผ€๋นˆ ๋ฒ ์ด์ปจ ๊ฒŒ์ž„์„ ํ–ˆ์„ ๋•Œ, ๋‚˜์˜ค๋Š” ๋‹จ๊ณ„์˜ ํ•ฉ์ด๋‹ค.

์˜ˆ๋ฅผ ๋“ค์–ด, BOJ์˜ ์œ ์ €๊ฐ€ 5๋ช…์ด๊ณ , 1๊ณผ 3, 1๊ณผ 4, 2์™€ 3, 3๊ณผ 4, 4์™€ 5๊ฐ€ ์นœ๊ตฌ์ธ ๊ฒฝ์šฐ๋ฅผ ์ƒ๊ฐํ•ด๋ณด์ž.

1์€ 2๊นŒ์ง€ 3์„ ํ†ตํ•ด 2๋‹จ๊ณ„ ๋งŒ์—, 3๊นŒ์ง€ 1๋‹จ๊ณ„, 4๊นŒ์ง€ 1๋‹จ๊ณ„, 5๊นŒ์ง€ 4๋ฅผ ํ†ตํ•ด์„œ 2๋‹จ๊ณ„ ๋งŒ์— ์•Œ ์ˆ˜ ์žˆ๋‹ค. ๋”ฐ๋ผ์„œ, ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๋Š” 2+1+1+2 = 6์ด๋‹ค.

2๋Š” 1๊นŒ์ง€ 3์„ ํ†ตํ•ด์„œ 2๋‹จ๊ณ„ ๋งŒ์—, 3๊นŒ์ง€ 1๋‹จ๊ณ„ ๋งŒ์—, 4๊นŒ์ง€ 3์„ ํ†ตํ•ด์„œ 2๋‹จ๊ณ„ ๋งŒ์—, 5๊นŒ์ง€ 3๊ณผ 4๋ฅผ ํ†ตํ•ด์„œ 3๋‹จ๊ณ„ ๋งŒ์— ์•Œ ์ˆ˜ ์žˆ๋‹ค. ๋”ฐ๋ผ์„œ, ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๋Š” 2+1+2+3 = 8์ด๋‹ค.

3์€ 1๊นŒ์ง€ 1๋‹จ๊ณ„, 2๊นŒ์ง€ 1๋‹จ๊ณ„, 4๊นŒ์ง€ 1๋‹จ๊ณ„, 5๊นŒ์ง€ 4๋ฅผ ํ†ตํ•ด 2๋‹จ๊ณ„ ๋งŒ์— ์•Œ ์ˆ˜ ์žˆ๋‹ค. ๋”ฐ๋ผ์„œ, ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๋Š” 1+1+1+2 = 5์ด๋‹ค.

4๋Š” 1๊นŒ์ง€ 1๋‹จ๊ณ„, 2๊นŒ์ง€ 3์„ ํ†ตํ•ด 2๋‹จ๊ณ„, 3๊นŒ์ง€ 1๋‹จ๊ณ„, 5๊นŒ์ง€ 1๋‹จ๊ณ„ ๋งŒ์— ์•Œ ์ˆ˜ ์žˆ๋‹ค. 4์˜ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๋Š” 1+2+1+1 = 5๊ฐ€ ๋œ๋‹ค.

๋งˆ์ง€๋ง‰์œผ๋กœ 5๋Š” 1๊นŒ์ง€ 4๋ฅผ ํ†ตํ•ด 2๋‹จ๊ณ„, 2๊นŒ์ง€ 4์™€ 3์„ ํ†ตํ•ด 3๋‹จ๊ณ„, 3๊นŒ์ง€ 4๋ฅผ ํ†ตํ•ด 2๋‹จ๊ณ„, 4๊นŒ์ง€ 1๋‹จ๊ณ„ ๋งŒ์— ์•Œ ์ˆ˜ ์žˆ๋‹ค. 5์˜ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๋Š” 2+3+2+1 = 8์ด๋‹ค.

5๋ช…์˜ ์œ ์ € ์ค‘์—์„œ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์€ 3๊ณผ 4์ด๋‹ค.

BOJ ์œ ์ €์˜ ์ˆ˜์™€ ์นœ๊ตฌ ๊ด€๊ณ„๊ฐ€ ์ž…๋ ฅ์œผ๋กœ ์ฃผ์–ด์กŒ์„ ๋•Œ, ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์„ ๊ตฌํ•˜๋Š” ํ”„๋กœ๊ทธ๋žจ์„ ์ž‘์„ฑํ•˜์‹œ์˜ค.

์ž…๋ ฅ

์ฒซ์งธ ์ค„์— ์œ ์ €์˜ ์ˆ˜ N (2 ≤ N ≤ 100)๊ณผ ์นœ๊ตฌ ๊ด€๊ณ„์˜ ์ˆ˜ M (1 ≤ M ≤ 5,000)์ด ์ฃผ์–ด์ง„๋‹ค. ๋‘˜์งธ ์ค„๋ถ€ํ„ฐ M๊ฐœ์˜ ์ค„์—๋Š” ์นœ๊ตฌ ๊ด€๊ณ„๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. ์นœ๊ตฌ ๊ด€๊ณ„๋Š” A์™€ B๋กœ ์ด๋ฃจ์–ด์ ธ ์žˆ์œผ๋ฉฐ, A์™€ B๊ฐ€ ์นœ๊ตฌ๋ผ๋Š” ๋œป์ด๋‹ค. A์™€ B๊ฐ€ ์นœ๊ตฌ์ด๋ฉด, B์™€ A๋„ ์นœ๊ตฌ์ด๋ฉฐ, A์™€ B๊ฐ€ ๊ฐ™์€ ๊ฒฝ์šฐ๋Š” ์—†๋‹ค. ์นœ๊ตฌ ๊ด€๊ณ„๋Š” ์ค‘๋ณต๋˜์–ด ๋“ค์–ด์˜ฌ ์ˆ˜๋„ ์žˆ์œผ๋ฉฐ, ์นœ๊ตฌ๊ฐ€ ํ•œ ๋ช…๋„ ์—†๋Š” ์‚ฌ๋žŒ์€ ์—†๋‹ค. ๋˜, ๋ชจ๋“  ์‚ฌ๋žŒ์€ ์นœ๊ตฌ ๊ด€๊ณ„๋กœ ์—ฐ๊ฒฐ๋˜์–ด์ ธ ์žˆ๋‹ค. ์‚ฌ๋žŒ์˜ ๋ฒˆํ˜ธ๋Š” 1๋ถ€ํ„ฐ N๊นŒ์ง€์ด๋ฉฐ, ๋‘ ์‚ฌ๋žŒ์ด ๊ฐ™์€ ๋ฒˆํ˜ธ๋ฅผ ๊ฐ–๋Š” ๊ฒฝ์šฐ๋Š” ์—†๋‹ค.

์ถœ๋ ฅ

์ฒซ์งธ ์ค„์— BOJ์˜ ์œ ์ € ์ค‘์—์„œ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์„ ์ถœ๋ ฅํ•œ๋‹ค. ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ์—ฌ๋Ÿฌ ๋ช…์ผ ๊ฒฝ์šฐ์—๋Š” ๋ฒˆํ˜ธ๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์„ ์ถœ๋ ฅํ•œ๋‹ค.

์˜ˆ์ œ ์ž…๋ ฅ 1 ๋ณต์‚ฌ

5 5
1 3
1 4
4 5
4 3
3 2

์˜ˆ์ œ ์ถœ๋ ฅ 1 ๋ณต์‚ฌ

3

# ํ’€์ด ๋ฐฉ๋ฒ•

์ฒ˜์Œ์— ๋ณ„ ์ƒ๊ฐ์—†์ด dfs๋กœ ์ ‘๊ทผํ•˜๋‹ค๊ฐ€ ์ž˜๋ชป๋˜์—ˆ์Œ์„ ํ™•์ธํ–ˆ๋‹ค. ๊ทธ๋ž˜์„œ bfs๋กœ ์ˆ˜์ •

A์™€ B์‚ฌ์ด์˜ ๋‹จ๊ณ„๋ฅผ ๊ณ„์‚ฐํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” ์ตœ๋‹จ ๋‹จ๊ณ„๋ฅผ ๊ณ ๋ คํ•ด์•ผ ํ•˜๋Š”๋ฐ dfs๋กœ ํ•  ๋•Œ๋Š” ๋ถˆ๊ฐ€๋Šฅํ•˜๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.

(๊ฐ„์„  ๊ฐ€์ค‘์น˜๊ฐ€ ๋™์ผํ•  ๋•Œ ์ตœ๋‹จ ๊ฒฝ๋กœ๋Š” bfs๋กœ ๊ตฌํ•  ์ˆ˜ ์žˆ๋‹ค.) 

bfs๋กœ ๋ฐ”๊พธ๊ณ  ๋‚˜๋จธ์ง€๋Š” ํฌ๊ฒŒ ์–ด๋ ต์ง€ ์•Š์•˜๋‹ค.


# ์ฝ”๋“œ

# 2024-04-19 01:30-54
import sys
sys.stdin = open("input.txt","r")
from collections import deque
MAX = 1e7

n, m = map(int,sys.stdin.readline().split())
graph = [[] for _ in range(n+1)]
for _ in range(m):
    a, b = map(int,sys.stdin.readline().split())
    graph[a].append(b);graph[b].append(a)

def bfs(start, target):
    visited = [False] * (n+1)

    queue = deque()
    queue.append((start,0))
    visited[start] = True

    while queue:
        curr, cnt = queue.popleft()
        if curr == target:
            return cnt
        for g in graph[curr]:
            if not visited[g]:
                visited[g] = True
                queue.append((g,cnt+1))
    

min_cnt = MAX
min_i = -1
for i in range(1,n+1):
    total_cnt = 0
    for j in range(1,n+1):
        total_cnt += bfs(i,j)
    if total_cnt < min_cnt:
        min_cnt = total_cnt; min_i = i

print(min_i)