[Algorithm] 백준 - 3055번 탈출 (Swift)

2024. 6. 15. 10:09· → Problems
목차
  1. 문제 소개
  2. 문제 풀이

문제 소개

문제 풀이

bfs 를 두번 활용하여 구했다. 물이 퍼지는 것을 moveWater() 로 구현했고, 고슴도치가 움직이는 것도 bfs 를 활용하여 구현했다.

import Foundation

let rc = readLine()!.split(separator: " ").map { Int($0)! }
let (r, c) = (rc[0], rc[1])
let ds = [(1, 0), (0, 1), (-1, 0), (0, -1)]

var map = [[String]]()
var queue: [(Int, Int, Int)] = []
var idx = 0
var widx = 0

var water: [(Int, Int, Int)] = []
var cave = (-1, -1)

for i in 0..<r {
    let input = Array(readLine()!).map { String($0) }
    map.append(input)
    
    for j in 0..<c {
        if input[j] == "S" {
            queue.append((i, j, 0))
        }
        
        if input[j] == "*" {
            water.append((i, j, 0))
        }
        
        if input[j] == "D" {
            cave = (i, j)
        }
    }
}

func moveWater(_ time: Int) {
    while water.count > widx {
        let popped = water[widx]
        if popped.2 > time { break }
        widx += 1
        
        for d in ds {
            let i = popped.0 + d.0
            let j = popped.1 + d.1
                        
            if 0..<r ~= i && 0..<c ~= j {
                if map[i][j] == "." {
                    map[i][j] = "*"
                    water.append((i, j, popped.2 + 1))
                }
            }
        }
    }
}

var visit = Array(repeating: Array(repeating: false, count: c), count: r)

while queue.count > idx {
    let popped = queue[idx]
    idx += 1
    
    moveWater(popped.2)
    
    for d in ds {
        let i = popped.0 + d.0
        let j = popped.1 + d.1
                
        if 0..<r ~= i && 0..<c ~= j {
            if map[i][j] == "." {
                if !visit[i][j] {
                    visit[i][j] = true
                    queue.append((i, j, popped.2 + 1))
                }
            }
            
            if map[i][j] == "D" {
                print(popped.2 + 1)
                exit(0)
            }
        }
    }
}

print("KAKTUS")

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

[Algorithm] 백준 - 2467번 용액 (Swift)  (0) 2024.06.17
[Algorithm] 백준 - 2166번 다각형의 면적 (Swift) (CCW 알고리즘)  (0) 2024.06.17
[Algorithm] 백준 - 16954번 움직이는 미로 탈출 (Swift)  (1) 2024.06.14
[Algorithm] 백준 - 16933번 벽 부수고 이동하기 3 (Swift)  (1) 2024.06.13
[Algorithm] 백준 - 14442번 벽 부수고 이동하기 2 (Swift)  (0) 2024.06.13
  1. 문제 소개
  2. 문제 풀이
'→ Problems' 카테고리의 다른 글
  • [Algorithm] 백준 - 2467번 용액 (Swift)
  • [Algorithm] 백준 - 2166번 다각형의 면적 (Swift) (CCW 알고리즘)
  • [Algorithm] 백준 - 16954번 움직이는 미로 탈출 (Swift)
  • [Algorithm] 백준 - 16933번 벽 부수고 이동하기 3 (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] 백준 - 3055번 탈출 (Swift)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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