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

2024. 10. 15. 15:09·PS/백준
반응형

문제

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

 

입력

n: Int = 정점의 개수
m: Int = 간선의 개수

u: 간선의 정점1
v: 간선의 점점2

1 <= n <= 1000
0 <= m <= (n*(n-1))/2
u != v

결과

ans: Int = 그래프에 존재하는 연결 컴포넌트 개수

해석

제공된 간선 정보를 이용해서 인접 행렬을 채운다.

이후 dfs를 통해 방문여부를 갱신하여 중복하여 방문하는 문제를 해결한다.

코드

import Foundation

let nm = readLine()!.split{$0 == " "}.map{Int($0)!}

let (n, m) = (nm[0], nm[1])

var adj: [[Int]] = [[Int]](repeating: [], count: n+1)

for _ in 0..<m {
    let ab = readLine()!.split{$0 == " "}.map{Int($0)!}
    let (a,b) = (ab[0], ab[1])
    adj[a].append(b)
    adj[b].append(a)
}

var visited: [Bool] = [Bool](repeating: false, count: n+1)


func dfs(_ now: Int) {
     visited[now] = true
    
    for next in adj[now]{
        if visited[next] {
            continue
        }
        dfs(next)
    }
    
}

var ans: Int = 0

for root in 1...n {
    if !visited[root] {
        dfs(root)
        ans += 1
    }
}

print(ans)

 

반응형

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

[백준] 2667 단지번호붙이기  (1) 2024.10.15
[백준] 1450 냅색문제  (0) 2024.10.15
[백준] 1806 부분합  (0) 2024.10.14
[백준] 2470 두 용액  (0) 2024.10.14
[백준] 3273 두 수의 합  (0) 2024.10.14
'PS/백준' 카테고리의 다른 글
  • [백준] 2667 단지번호붙이기
  • [백준] 1450 냅색문제
  • [백준] 1806 부분합
  • [백준] 2470 두 용액
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (304)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (37)
        • swift (32)
        • python (4)
        • Kotlin (1)
      • iOS (132)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (32)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (13)
        • 어노테이션 (1)
        • 튜토리얼 (11)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (0)
        • 이론 (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    백준
    Tuist
    Swift
    concurrency
    프로그래머스
    AVFoundation
    GIT
    dp
    lifecycle
    protocol
    boostcamp
    투포인터
    UIKit
    Spring
    dispatch
    IOS
    dfs
    property
    SwiftUI
    CS
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[백준] 11724 연결 요소의 개수
상단으로

티스토리툴바