11724번 : 연결 요소의 개수 - Python

Pobi·2023년 3월 27일
0

PS

목록 보기
50/107

문제

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

풀이

DFS를 이용해서 연결 요소들을 카운트 한다. DFS를 한번 했다는 것은 1개의 연결 요소를 구했다는 말이다. 물론 BFS로도 풀 수 있다.
파이썬에서 DFS를 이용해서 풀다가 RecursionError가 날 수 있다. 제귀 깊이의 한계때문에 나는 Error이니 제귀 깊이를 변경해보자.

코드

import sys 
sys.setrecursionlimit(10**6) #제귀 깊이 변경

input = sys.stdin.readline

#dfs
def dfs(array, n, visit):
    if visit[n]!=0:
        return
    
    visit[n] = 1

    for i in range(len(array[n])):
        if array[n][i] == 1:
            dfs(array, i, visit)
        

n, m = map(int,input().split())
array = [[0 for j in range(n+1)] for i in range(n+1)]
visit = [0 for i in range(n+1)]
count = 0

for i in range(m):
    x, y = map(int,input().split())
    array[x][y] = array[y][x] = array[x][x] = array[y][y] = 1

#dfs로 방문 안한 곳들은 연결되어 있는 노드까지 한번 돌기
for i in range(1, n+1):
    if visit[i] == 0:
        dfs(array,i,visit)
        count+=1

print(count)
profile
꿈 많은 개발자

0개의 댓글