Doby's Lab

백준 2606번: 바이러스 (Python) 본문

PS/BOJ

백준 2606번: 바이러스 (Python)

도비(Doby) 2023. 12. 2. 15:52

 

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

 

2606번: 바이러스

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

www.acmicpc.net


Level: Silver III

Solved By: BFS

 

BFS를 통해서 1번 노드로부터 연결된 모든 노드를 찾는 문제였습니다.

from collections import deque

N = int(input())
M = int(input())

adj = [[] for i in range(0, N + 1)]
visited = [False for _ in range(0, N + 1)]


def bfs(node):
    q = deque([node])
    visited[node] = True
    ret = 0

    while(len(q) != 0):
        now = q.popleft()

        for nxt in adj[now]:
            if(not visited[nxt]):
                visited[nxt] = True
                q.append(nxt)
                ret += 1

    return ret


for _ in range(M):
    a, b = map(int, input().split())
    adj[a].append(b)
    adj[b].append(a)

print(bfs(1))

 

 

 

 

728x90