๐Ÿ—๏ธ Algorithm/๐ŸŸฉ ๋ฐฑ์ค€

๐ŸŸฉ [๋ฐฑ์ค€] [Python] 24444๋ฒˆ_์•Œ๊ณ ๋ฆฌ์ฆ˜ ์ˆ˜์—… - ๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰ 1

Dbswnstjd 2022. 12. 16. 23:43

๋ฌธ์ œ

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

 

24444๋ฒˆ: ์•Œ๊ณ ๋ฆฌ์ฆ˜ ์ˆ˜์—… - ๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰ 1

์ฒซ์งธ ์ค„์— ์ •์ ์˜ ์ˆ˜ N (5 ≤ N ≤ 100,000), ๊ฐ„์„ ์˜ ์ˆ˜ M (1 ≤ M ≤ 200,000), ์‹œ์ž‘ ์ •์  R (1 ≤ R ≤ N)์ด ์ฃผ์–ด์ง„๋‹ค. ๋‹ค์Œ M๊ฐœ ์ค„์— ๊ฐ„์„  ์ •๋ณด u v๊ฐ€ ์ฃผ์–ด์ง€๋ฉฐ ์ •์  u์™€ ์ •์  v์˜ ๊ฐ€์ค‘์น˜ 1์ธ ์–‘๋ฐฉ

www.acmicpc.net

ํ’€์ด

# ๋ฐฑ์ค€ 24444๋ฒˆ ๋ฌธ์ œ - ์•Œ๊ณ ๋ฆฌ์ฆ˜ ์ˆ˜์—… - ๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰ 1
from collections import deque
import sys
input = sys.stdin.readline
n, m, r = map(int, input().split())
graph = [[] for _ in range(n+1)]
visited = [0] * (n+1)
for _ in range(m):
    a, b = map(int, input().split())
    graph[a].append(b)
    graph[b].append(a)

def bfs(n):
    q = deque()
    q.append(n)
    visited[n] = 1
    count = 1
    while q:
        v = q.popleft()
        graph[v].sort()
        for i in graph[v]:
            if not visited[i]:
                count += 1
                visited[i] = count
                q.append(i)

bfs(r)
for i in visited[1:]:
    print(i)

์ด์ „์— ํ’€์—ˆ๋˜ ๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰ 2์™€ ๊ฐ™์€ ์œ ํ˜•์ด๋ผ ์‰ฝ๊ฒŒ ํ’€ ์ˆ˜ ์žˆ์—ˆ๋‹ค. 

sys๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ์•ผ ์‹œ๊ฐ„์ดˆ๊ณผ๊ฐ€ ๋‚˜์ง€ ์•Š๊ณ  ํ•ด๊ฒฐ์ด ๊ฐ€๋Šฅํ•˜๋‹ค.