[Algorithm] 백준 - 16964번 DFS 스페셜 저지 (Swift)

2024. 5. 14. 17:24· → Problems
목차
  1. 문제 해석
  2. 문제 풀이

문제 해석

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

dfs로 풀라고 만든 문제이다. dfs방문순서가 맞는지 물어보는 문제이다. 보통은 dfs로 결과를 찾아나가는데, dfs자체를 검증하는 문제는 신선했다.

문제 풀이

체크하려는 배열에서 우선순위를 priority 딕셔너리 타입으로 만든다음에 저장한뒤 이 우선순위대로 graph를 재배열 하는 방식으로 풀었다. 그 이후 dfs를 돌려(?) 결과값을 비교했다.

import Foundation

let n = Int(readLine()!)!
var graph = Array(repeating: [Int](), count: n + 1)

for _ in 1..<n {
    let info = readLine()!.split(separator: " ").map { Int(String($0))! }
    let (a, b) = (info[0], info[1])
    graph[a].append(b)
    graph[b].append(a)
}

let check = readLine()!.split(separator: " ").map { Int(String($0))! }
if check[0] != 1 {
    print(0)
    exit(0)
}

var priority = [Int: Int]()
for i in check.indices {
    priority[check[i]] = i
}

var idx = 0
var visited = Array(repeating: false, count: n+1)

for i in 1...n {
    graph[i].sort(by: { priority[$0]! < priority[$1]! })
}

var answer = [Int]()

func dfs(_ i: Int) {
    if visited[i] { return }
    answer.append(i)
    visited[i] = true
    
    for i in graph[i] {
        if !visited[i] {
            dfs(i)
        }
    }
}

dfs(1)

if answer == check {
    print(1)
} else {
    print(0)
}

'→ Problems' 카테고리의 다른 글

[Algorithm] 백준 - 13913번 숨바꼭질4 (Swift)  (0) 2024.05.21
[Algorithm] 백준 - 2146번 다리 만들기 (Swift)  (0) 2024.05.20
[Algorithm] 백준 - 16940번 BFS 스페셜 저지 (Swift)  (0) 2024.05.14
[Algorithm] 백준 - 7576번 토마토 (Swift)  (0) 2024.05.13
[Algorithm] 백준 - 2178번 미로 탐색 (Swift)  (0) 2024.05.13
  1. 문제 해석
  2. 문제 풀이
'→ Problems' 카테고리의 다른 글
  • [Algorithm] 백준 - 13913번 숨바꼭질4 (Swift)
  • [Algorithm] 백준 - 2146번 다리 만들기 (Swift)
  • [Algorithm] 백준 - 16940번 BFS 스페셜 저지 (Swift)
  • [Algorithm] 백준 - 7576번 토마토 (Swift)
Swift librarian
Swift librarian
Swift LibrarySwift librarian 님의 블로그입니다.
Swift librarian
Swift Library
Swift librarian
전체
오늘
어제
  • 분류 전체보기 (231)
    • 📺 Programming (5)
    • → Architecture (2)
    • → Design Pattern (0)
    • → Computer Science (15)
    • ⚙️ Algorithm (0)
    • → 알고리즘 관련 (22)
    • → Problems (104)
    • 🚀 Project (0)
    • → 알쏭달쏭 (0)
    • → Shook (2)
    • → Solver (8)
    • → Taster (7)
    • → Outline (4)
    • → Pointer (2)
    • → Guesser (3)
    • 🦜 Swift (2)
    • → Swift Archive (12)
    • → Swift Study (12)
    • → Xcode (6)
    • 🧰 Framework (0)
    • → Foundation (1)
    • → UIKit (2)
    • → SwiftUI (3)
    • → CoreData (2)
    • → MapKit (1)
    • → CoreHaptic (1)
    • → User Notification (1)
    • → StoreKit (2)
    • 🏛️ Library (0)
    • → TCA (0)
    • 🐈‍⬛ Git (8)
    • → Git의 원리 (2)
    • → Git 심화 (1)
    • 📦 Other (1)
    • 👦🏻 Log (0)

최근 글

hELLO · Designed By 정상우.v4.2.2
Swift librarian
[Algorithm] 백준 - 16964번 DFS 스페셜 저지 (Swift)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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