๐ŸŒžAlgorithm/๐Ÿ”ฅBaekjoon

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

๋ฟŒ์•ผ._. 2022. 3. 8. 23:21

Silver I

๋ฌธ์ œ(์ถœ์ฒ˜: https://www.acmicpc.net/problem/1389)

<์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 6๋‹จ๊ณ„ ๋ฒ•์น™>

๋ฌธ์ œ 

 

์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ 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์˜ ์œ ์ € ์ค‘์—์„œ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์„ ์ถœ๋ ฅํ•œ๋‹ค. ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ์—ฌ๋Ÿฌ ๋ช…์ผ ๊ฒฝ์šฐ์—๋Š” ๋ฒˆํ˜ธ๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ์„ ์ถœ๋ ฅํ•œ๋‹ค.

 

 

๋ฌธ์ œ ํ’€์ด

- my solution

import sys

def bfs(graph, start, depth):
    queue=[start]
    while queue:
        temp=queue.pop(0)
        for i in graph[temp]:
            if depth[i]==0 and i!=start: # ์•„์ง ๋ฐฉ๋ฌธํ•˜์ง€ ์•Š์•˜์œผ๋ฉด
                depth[i]=depth[temp]+1
                queue.append(i)

if __name__=='__main__':
    n,m=map(int, sys.stdin.readline().split()) # ์œ ์ €์˜ ์ˆ˜, ์นœ๊ตฌ ๊ด€๊ณ„์˜ ์ˆ˜

    friend={}
    for i in range(n):
        friend[i+1]=[]

    for i in range(m): # ์นœ๊ตฌ ๊ด€๊ณ„
        a,b=map(int, sys.stdin.readline().split())
        friend[a].append(b)
        friend[b].append(a)

    result=[0]*(n+1)
    for i in range(1,n+1): 
        depth = [0] * (n + 1)
        bfs(friend, i, depth)
        result[i]=sum(depth) # ๋‹จ๊ณ„์˜ ํ•ฉ

    answer=result.index(min(result[1::])) # ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜๊ฐ€ ๊ฐ€์žฅ ์ž‘์€ ์‚ฌ๋žŒ
    print(answer)

 

  • bfs
    : queue๊ฐ€ ๋นŒ ๋•Œ๊นŒ์ง€ ๋ฐ˜๋ณต: ์ œ์ผ ์ฒ˜์Œ ๊ฐ’ pop ํ•ด์„œ ๊ทธ์™€ ์—ฐ๊ฒฐ๋œ ์นœ๊ตฌ์™€ ์—ฐ๊ฒฐ๋˜์ง€ ์•Š์•˜๋‹ค๋ฉด ๊ฑฐ๋ฆฌ(ํ˜„์žฌ ๋„์‹œ depth์˜ +1) ์ €์žฅ ๋ฐ queue์— ์ถ”๊ฐ€
  • main
    : ์œ ์ €์˜ ์ˆ˜, ์นœ๊ตฌ ๊ด€๊ณ„์˜ ์ˆ˜ ์ž…๋ ฅ
    : friend = dict {key(์œ ์ €) : value(์นœ๊ตฌ)}
    : result = ๊ฐ ์œ ์ €์˜ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜ ์ €์žฅ (depth์˜ ํ•ฉ)
    : ๋ฐ˜๋ณต๋ฌธ์„ ํ†ตํ•ด ๊ฐ ์œ ์ €์˜ ์ผ€๋นˆ ๋ฒ ์ด์ปจ์˜ ์ˆ˜ ๊ตฌํ•˜๊ธฐ
    : answer = result ์ค‘ ๊ฐ€์žฅ ์ž‘์€ index
    result [1::] -> ๊ฐ ์œ ์ € ๋ฒˆํ˜ธ๋Œ€๋กœ ์ €์žฅํ•˜๊ธฐ ์œ„ํ•ด 0๋ฒˆ์„ ๋น„์›€

์ƒ๊ฐ๐Ÿค”

 

์ฒ˜์Œ์— ๋ฌธ์ œ ๊ธธ์ด๊ฐ€ ๋„ˆ๋ฌด ๊ธธ์–ด์„œ ํ’€๊นŒ ๋ง๊นŒ ๊ณ ๋ฏผํ–ˆ์ง€๋งŒ ๋„์ „ -!

ํŠน์ • ๊ฑฐ๋ฆฌ๋ฅผ ๊ณ„์‚ฐํ•˜๋Š” ๋ฌธ์ œ์™€ ๋น„์Šทํ•˜๊ฒŒ ๊ตฌํ˜„ํ•˜์—ฌ ๋ฌธ์ œ๋ฅผ ์‰ฝ๊ฒŒ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ์—ˆ๋‹ค.