방향 없는 그래프가 주어졌을 때, 연결 요소 (Connected Component)의 개수를 구하는 프로그램을 작성하시오.
6 5
1 2
2 5
5 1
3 4
4 6
2
6 8
1 2
2 5
5 1
3 4
4 6
5 4
2 4
2 3
1
import sys
sys.setrecursionlimit(10**5) # 재귀 제한 늘림
def DFS(node): # DFS 함수
ch[node] = 1 # 인자로 받은 node를 지나간 것으로 체크
edge = edges[node] # 현재 node에 연결된 edge들 확인
while edge: # edge가 존재할 때 까지 반복
next = edge.pop()
if ch[next] == 0: # edge에 연결된 반대편 node가 지나가지 않은 것이라면 recursion 수행
DFS(next)
# 메인함수
if __name__ == "__main__":
n, m = map(int, sys.stdin.readline().split())
graph = 0 # 그래프의 개수
edges = [[] for _ in range(n+1)] # 각 노드에서 edge로 연결된 노드들 모아놓음.
ch = [0] * (n + 1) # 지나간 node인지 확인하는 리스트
for _ in range(m):
# edge 입력받은 후에 edges에 저장.
a, b = map(int, sys.stdin.readline().split())
edges[a].append(b)
edges[b].append(a)
for i in range(1, n + 1):
if ch[i] == 0: # 지나가지 않은 노드들 확인
graph += 1 # 이전의 그래프에서 지나가지 않은 것이므로 새로운 그래프.
DFS(i)
print(graph)