[Python] 백준 11724 - 연결 요소의 개수

2021. 11. 7. 22:33·IT/알고리즘
반응형

문제

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

문제 해결방법

bfs 로 해결 가능

노드별로 방문 결과에 대해 방문결과 값을 업데이트 하고 방문결과가 있는 노드는 skip 하고 
방문 안한 노드는 방문해서 총 몇번 반복 되는지

문제 풀이

import sys
from collections import deque

N, M = map(int, sys.stdin.readline().strip().split())
graph = dict()
for _ in range(M):
    a, b = map(int, sys.stdin.readline().strip().split())
    graph.setdefault(a, { b }) if a not in graph.keys() else graph[a].add(b)
    graph.setdefault(b, { a }) if b not in graph.keys() else graph[b].add(a)


def bfs(root):
    visited = []
    queue = deque([root])

    if root not in graph.keys():
        return visited

    while queue:
        node = queue.popleft()
        if node not in visited:
            visited.append(node)
            queue.extend(list(graph[node] - set(visited)))

    return visited


count = 0
is_visited = [0] * (N + 1)

for i in range(1, N + 1):
    if is_visited[i] == 0:
        visit = bfs(i)

        for v in visit:
            is_visited[v] = 1
        count += 1
print(count)
728x90
반응형
저작자표시 비영리 변경금지 (새창열림)
'IT/알고리즘' 카테고리의 다른 글
  • [백준] 9372 파이썬(python)
  • [백준] 7569 파이썬(python)
  • [Python] 백준 7576 - 토마토
  • [Python] 백준 1012 - 유기농 배추
상쾌한기분
상쾌한기분
  • 상쾌한기분
    상쾌한기분
    상쾌한기분
  • 전체
    오늘
    어제
    • 분류 전체보기 (251)
      • Python (44)
        • Python (26)
        • Django (6)
        • Flask (4)
        • Open Source (6)
      • Kotlin & Java (5)
        • Spring (2)
        • 프로젝트 (1)
      • Go (11)
      • Database (24)
        • MySQL (21)
        • Redis (3)
      • Infrastructure (2)
        • CDC (4)
        • Kafka (5)
        • Prometheus (2)
        • Fluentd (11)
        • Docker (1)
        • Airflow (2)
        • VPN (2)
      • IT (26)
        • AI (9)
        • Langchain (8)
        • Web (18)
        • Git (8)
        • 리팩토링 (9)
        • Micro Service Architecture (8)
        • Clean Code (16)
        • Design Pattern (0)
        • 수학 (1)
        • 알고리즘 (14)
      • OS (14)
        • Centos (10)
        • Ubuntu (3)
        • Mac (1)
      • Search Engine (2)
        • ElasticSearch (1)
        • Lucene Solr (1)
      • PHP (2)
        • Laravel (1)
        • Codeigniter (1)
  • 블로그 메뉴

    • Github 방문
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    python
    파이썬
    Kafka
    prompt
    fluentd
    Redis
    docker
    백준
    Langchain
    티스토리챌린지
    ollama
    git
    http
    Golang
    LLM
    performance
    오블완
    CDC
    MYSQL
    go
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
상쾌한기분
[Python] 백준 11724 - 연결 요소의 개수
상단으로

티스토리툴바