PS/백준

실버3 바이러스(2606)

2023. 12. 2. 23:33
 

2606번: 바이러스

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

www.acmicpc.net

바이러스 문제는 DFS와 BFS를 활용해서 풀 수 있는 간단한 문제입니다. 알고리즘2 수강하면서 풀다보니 CC(Connected Component)배우면서 유형이 비슷하다고 생각했습니다.

# 바이러스
# https://www.acmicpc.net/problem/2606 

import sys
from collections import deque
input = sys.stdin.readline

def bfs(graph, visited, node):
  queue = deque()
  queue.append(node)  
  visited[node] = True
  while queue:
    start = queue.popleft()
    for connectedNode in graph[start]:
      if not visited[connectedNode]:
        queue.append(connectedNode)
        visited[connectedNode] = True
  return visited

def dfs(graph, visited, node):
  visited[node] = True
  for connectedNode in graph[node]:
    if not visited[connectedNode]:
      dfs(graph, visited, connectedNode)
  return visited

v, e = int(input()), int(input())
connectedList = [[] for _ in range(v+1)]
visited = [False] * (v+1)

for i in range(e):
  x,y = map(int, input().split())
  connectedList[x].append(y)
  connectedList[y].append(x)

print(bfs(connectedList, visited, 1).count(True)-1)

위와 같이 풀이를 했습니다. DFS와 BFS에 대해서 오랜만에 하다보니 다시 공부해야 할것 같아서 두가지 방법을 모두 구현했습니다.

인접 리스트를 활용해서 DFS와 BFS를 했고, 반환 값을 visited로 반환하여 True를 count하여 계산했습니다.

'PS > 백준' 카테고리의 다른 글

골드5 뱀과 사다리 게임(16928)  (1) 2023.12.28
골드5 토마토(7569)  (0) 2023.12.27
골드5 토마토(7576)  (1) 2023.12.26
실버1 나이트의 이동(7562)  (1) 2023.12.22
실버2 유기농 배추(1012)  (1) 2023.12.21
'PS/백준' 카테고리의 다른 글
  • 골드5 토마토(7569)
  • 골드5 토마토(7576)
  • 실버1 나이트의 이동(7562)
  • 실버2 유기농 배추(1012)
jjw000628
jjw000628
jjw000628
wldnd2
jjw000628
전체
오늘
어제
  • 분류 전체보기 (27)
    • Skill Up (1)
      • Algorithm Theory (1)
      • Java (0)
      • JS (0)
      • 프로젝트 및 회고 (0)
    • PS (23)
      • 백준 (15)
      • 프로그래머스 (8)
    • Lab (3)
      • Basic Concept (0)
      • 무선 이동 통신 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 그래프탐색
  • 파싱
  • JS
  • 네트워크
  • 정규식
  • 무선
  • 백준
  • 문자열
  • DP
  • 프로그래머스
  • BFS
  • 브루트포스
  • 깊이우선탐색
  • 누적합
  • 재귀
  • dfs
  • 분할정복
  • Cpp
  • 그래프
  • 알고리즘
  • 파이썬
  • 너비우선탐색
  • C++

최근 댓글

최근 글

hELLO · Designed By 정상우.
jjw000628
실버3 바이러스(2606)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.