티스토리 뷰

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

import sys
sys.setrecursionlimit(10000)

N, M = map(int, sys.stdin.readline().split())
matrix = [[0] * N for _ in range(N)]
check = [0] * N
cnt = 0

def dfs(n):
    check[n] = 1
    for i in range(N):
        if check[i] == 0 and matrix[n][i] == 1:
            dfs(i)


for i in range(M):
    u, v = map(int, sys.stdin.readline().split())

    matrix[u-1][v-1] = 1
    matrix[v-1][u-1] = 1


for i in range(N):
    if check[i] == 0:
        dfs(i)
        cnt += 1

print(cnt)
공지사항
최근에 올라온 글
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함