본문 바로가기
카테고리 없음

[백준] 2606. 바이러스 - Python

by 리버🐦‍🔥 2023. 9. 18.

[Silver III]

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

 

2606번: 바이러스

첫째 줄에는 컴퓨터의 수가 주어진다. 컴퓨터의 수는 100 이하인 양의 정수이고 각 컴퓨터에는 1번 부터 차례대로 번호가 매겨진다. 둘째 줄에는 네트워크 상에서 직접 연결되어 있는 컴퓨터 쌍

www.acmicpc.net

풀이

2차원 배열을 통해 네트워크(그래프)를 생성하고, BFS를 돌려 1번 컴퓨터와 연결된 컴퓨터의 개수를 센다.

from collections import deque

computers = []
visited = []
ans = 0

def solve(cur):
    global ans
    global visited
    global computers
    q = deque()
    q.append(cur)
    visited[cur] = True

    while q:
        cur = q.popleft()
        for i in computers[cur]:
            if not visited[i]:
                q.append(i)
                visited[i] = True
                ans += 1

# main
n = int(input())
m = int(input())

for i in range(n + 1):
    computers.append([])
    visited.append(False)

for i in range(m):
    a, b = map(int, input().split())
    computers[a].append(b)
    computers[b].append(a)

solve(1)
print(ans)