[프로그래머스] 미로 탈출

2024. 10. 4. 22:16·PS/프로그래머스
반응형

문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

입력

maps:[String] = 맵정보를 나타냄
O = 빈공간
X = 벽
S = 시작지점
L = 레버
E = 탈출

결과

ans: Int = 레버를 올린 후 도착지점까지 최소 시간,  도착 불가면 -1

해석

전형적인 bfs를 통한 최단거리 찾기 문제인 것 같다.

그런데 하나 다른 점은 반든시 레버 지점에 도착한 후 출구로 가야한다.

그렇다면 bfs를 두번 진행하면 될 듯하다.

 

1. 출발지 -> 레버

2. 레버 -> 출구 

 

코드

import Foundation

extension String {
    subscript(_ index: Int) -> String {
        return String(self[self.index(self.startIndex, offsetBy: index)])
    }
}

let dy = [-1,1,0,0]
let dx = [0,0,-1,1]

var ans: Int =  1000_000

typealias Pos = (Int, Int) 


func solution(_ maps:[String]) -> Int {
    
    var entryPos: Pos = (0,0)
    var leverPos: Pos = (0,0)
    var exitPos: Pos = (0,0)
    let n = maps.count
    let m = maps[0].count
    var index: Int = 0 
    var queue: [Pos]  = [] 
    
    for i in 0..<n {
        for j in 0..<m {
            if maps[i][j] == "S" {
                entryPos = (i,j)
            } else if maps[i][j] == "L" {
                leverPos = (i,j)
            } else if maps[i][j] == "E" {
                exitPos = (i,j)
            }
        }
    }
    
    // 각 위치 찾기
    
    var visited: [[Int]] = [[Int]](repeating: [Int](repeating: -1, count:m), count: n)
    
    visited[entryPos.0][entryPos.1] = 0 
    queue.append(entryPos)
    var leverMinTime = Int.max

    // 레버를 도착지로 bfs
    while index < queue.count {
        let pos = queue[index]
        let (x,y) = pos
        
        if pos == leverPos {
            leverMinTime = visited[x][y] // 레버 도착 최단시간 기록 
            break
        } 
        
        for i in 0..<4 {
            let nx = x + dx[i]
            let ny = y + dy[i]
            
            if nx < 0 || nx >= n  || ny < 0 || ny >= m { continue }
            if maps[nx][ny] == "X" { continue }
            if visited[nx][ny] != -1 { continue }
            
            visited[nx][ny] = visited[x][y] + 1
            queue.append((nx,ny))
        }
        
        index += 1 
    }
    
    // 만약 레버에 도착하지 못했다면 -1
    if visited[leverPos.0][leverPos.1] == -1 {
        return -1
    }
    
    visited = [[Int]](repeating: [Int](repeating: -1, count:m), count: n)
    queue.removeAll()
    queue.append(leverPos)
    visited[leverPos.0][leverPos.1] = leverMinTime  // 레버가 출발위치므로 시작시간은 위에서 구한 시간
    index = 0
    
    // 레버에서 출구로 bfs
    while index < queue.count {
        let pos = queue[index]
        let (x,y) = pos
        
        if pos == exitPos {
            break
        } 
        
        for i in 0..<4 {
            let nx = x + dx[i]
            let ny = y + dy[i]
            
            if nx < 0 || nx >= n  || ny < 0 || ny >= m { continue }
            if maps[nx][ny] == "X" { continue }
            if visited[nx][ny] != -1 { continue }
            
            visited[nx][ny] = visited[x][y] + 1
            queue.append((nx,ny))
        }
        
        index += 1 
    }
    
    
   
   return visited[exitPos.0][exitPos.1]
}

 

반응형

'PS > 프로그래머스' 카테고리의 다른 글

[백준] 16916 부분 문자열  (0) 2024.10.18
[프로그래머스] 무인도 여행  (4) 2024.10.04
[프로그래머스] 택배상자  (2) 2024.10.02
[프로그래머스] n + 1 카드게임  (0) 2024.10.01
[프로그래머스] 산 모양 타일링  (0) 2024.10.01
'PS/프로그래머스' 카테고리의 다른 글
  • [백준] 16916 부분 문자열
  • [프로그래머스] 무인도 여행
  • [프로그래머스] 택배상자
  • [프로그래머스] n + 1 카드게임
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (339)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • 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 (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (21)
        • 이론 (10)
        • MCP (1)
        • LangGraph (10)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 미로 탈출
상단으로

티스토리툴바