[Algorithm] 백준 - 16928번 뱀과 사다리 게임 (Swift)

2024. 6. 7. 13:57· → Problems
목차
  1. 문제 소개
  2. 문제 풀이
  3. DFS 를 활용한 풀이

문제 소개

https://www.acmicpc.net/problem/16928
뱀과 사다리 게임을 하는데 주사위를 굴려야 하는 횟수의 최솟값을 구하는 문제이다.

 

문제 풀이

DFS 를 활용한 풀이

board, visited 를 통해 보드의 정보, 방문여부를 저장하여 구현했다. 처음에 틀렸는데 이유는 뱀을 타고 내려가는 경우는 일부로 고려하지 않았는데, 뱀을 타고 내려가는 경우에도 빨리 도착하는 경우가 있다.

import Foundation

let nm = readLine()!.split(separator: " ").map { Int($0)! }
let (n, m) = (nm[0], nm[1])
var board = Array(repeating: 0, count: 101)
var visited = Array(repeating: false, count: 101)

for _ in 0..<n {
    let xy = readLine()!.split(separator: " ").map { Int($0)! }
    let (x, y) = (xy[0], xy[1])
    board[x] = y
}

for _ in 0..<m {
    let uv = readLine()!.split(separator: " ").map { Int($0)! }
    let (u, v) = (uv[0], uv[1])
    board[u] = v
}

let dice = [1, 2, 3, 4, 5, 6]

var queue = [(1, 0)]
var idx = 0
var answer = 0

while queue.count > idx {
    let poped = queue[idx]
    idx += 1
    
    if poped.0 >= 100 {
        answer = poped.1
        break
    }
    
    for num in dice {
        let next = poped.0 + num
        
        if next > 100 { continue }
        
        if !visited[next] {
            visited[next] = true
            queue.append((board[next] == 0 ? next : board[next], poped.1 + 1))
        }
    }
}

print(answer)

 
이 문제에서는 이것보다는 더 효율적으로 짤순 없을듯...? 하다.

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

[Algorithm] 백준 - 14502번 연구소 (Swift)  (1) 2024.06.09
[Algorithm] 백준 - 9019번 DSLR (Swift) (시간초과)  (1) 2024.06.08
[Algorithm] 백준 - 1062번 가르침 (Swift)  (1) 2024.06.06
[Algorithm] 백준 - 1987번 알파벳 (Swift) (비트마스크)  (0) 2024.06.05
[Algorithm] 백준 - 2580번 스도쿠 (Swift)  (0) 2024.06.04
  1. 문제 소개
  2. 문제 풀이
  3. DFS 를 활용한 풀이
'→ Problems' 카테고리의 다른 글
  • [Algorithm] 백준 - 14502번 연구소 (Swift)
  • [Algorithm] 백준 - 9019번 DSLR (Swift) (시간초과)
  • [Algorithm] 백준 - 1062번 가르침 (Swift)
  • [Algorithm] 백준 - 1987번 알파벳 (Swift) (비트마스크)
Swift librarian
Swift 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] 백준 - 16928번 뱀과 사다리 게임 (Swift)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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