알고리즘/baekjoon
[알고리즘/baekjoon] 11724_연결 요소의 개수(python)
천뿌니
2021. 11. 24. 21:09
728x90
문제
https://www.acmicpc.net/problem/11724
11724번: 연결 요소의 개수
첫째 줄에 정점의 개수 N과 간선의 개수 M이 주어진다. (1 ≤ N ≤ 1,000, 0 ≤ M ≤ N×(N-1)/2) 둘째 줄부터 M개의 줄에 간선의 양 끝점 u와 v가 주어진다. (1 ≤ u, v ≤ N, u ≠ v) 같은 간선은 한 번만 주
www.acmicpc.net
# 연결 요소의 개수를 구하는 문제이다.
# 예를 들어, 1-3-4 와 2-5-6으로 이뤄진 그래프가 있다면 여기서 연결 요소의 개수는 2개라고 할 수 있다.
# 간단히 dfs나 bfs를 사용하여 해결 가능하다.
정답
import sys
sys.setrecursionlimit(100000) # dfs 사용 시 재귀의 깊이를 더 늘려줘야 한다.(아니면 런타임 오류 발생)
n, m = map(int, sys.stdin.readline().split())
graph = [[]*(n+1) for _ in range(n+1)]
visited = [0] * (n+1)
count = 0
def dfs(v):
visited[v] = 1
for i in graph[v]:
if visited[i] == 0:
dfs(i)
for _ in range(m):
a, b = map(int, sys.stdin.readline().split())
graph[a].append(b)
graph[b].append(a)
for j in range(1, n+1):
if visited[j] == 0:
dfs(j)
count+=1
print(count)