카테고리 없음

[파이썬] 24483 알고리즘 수업 - 깊이 우선 탐색 5

takeU 2022. 8. 5. 15:28
반응형
import sys
sys.setrecursionlimit(10 ** 8)
input = sys.stdin.readline

n, m, r = map(int, input().split())
graph = [[] for _ in range(n + 1)]
visited = [[-1, 0] for _ in range(n + 1)]
count = 1

for _ in range(m):
    x, y = map(int, input().split())
    graph[x].append(y)
    graph[y].append(x)

def dfs(node):
    global count

    graph[node].sort()
    for g in graph[node]:
        if visited[g][0] == -1:
            count += 1
            visited[g] = [visited[node][0] + 1, count]
            dfs(g)

visited[r][0] = 0
dfs(r)

ans = 0
for v in visited[1:]:
    ans += v[0] * v[1]
print(ans)

dfs