[프로그래머스] 미로 탈출 명령어

2024. 9. 30. 21:26·PS/프로그래머스
반응형

문제

 

프로그래머스

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

programmers.co.kr

입력

n: Int = 세로 길이
m: Int = 가로 길이
x: Int = 초기 세로 위치
y: Int = 초기 가로 위치 
r: Int = 도착 세로 위치
c: Int = 도착 가로 위치 
k: Int = 제한

결과

이동거리가 k일 때 사전순으로 가장 빠른 방법을 출력 
l = 왼 
r = 오
d = 아래
u = 위

만약 방법이 없다면 impossible 문자열 출력

해석

1. 움직임에 대한 문자가 매칭되야하므로 열거형으로 하면 편할 것 같다.

2. 사전으로 가장 빠른 움직인 순서는 d l r u 순이니 이 순서로 방문을 하면 알아서 사전순은 맞춰질 듯하다.

3. 일단 기본적으로 dfs를 통해 진행을 하면되는데 여기서 현재위치로부터 도착지점까지 최소거리를 항상 체크해준다.

4. 방법이 없는 경우는 크게 2가지가 될 것 같다

  • 처음지점부터 도착지점까지 최소거리가 k를 넘을 때 
  • k - 최소거리  % 2  != 0 이면 불가능하다. 왜냐하면 짝수면 남은 횟수를 왕복하면되지만 홀수면 왕복이 불가능하여
    다시 도차직점으로 오는 것이 불가능하기 때문이다.

코드

import Foundation

enum Dir : String {
    case d
    case l
    case r
    case u
    
    var coord: (Int, Int) {
        switch self {
            
        case .l:
            return (0, -1)
        case .r:
            return (0, 1)
        case .u:
            return (-1, 0)
        case .d:
            return (1, 0)
        }
    }
    
}

let dirs: [Dir] = [.d, .l, .r, .u]

func minDist(_ x1: Int, _ y1: Int, _ x2: Int,_ y2: Int) -> Int {
    return abs(x1-x2) + abs(y1-y2)
} 

func solution(_ n:Int, _ m:Int, _ x:Int, _ y:Int, _ r:Int, _ c:Int, _ k:Int) -> String {
    // n = 세로 길이
    // m = 가로 길이
    // x = 초기 세로 위치
    // y = 초기 가로 위치 
    // r = 도착 세로 위치
    // c = 도착 가로 위치 
    // k = 제한

    var ans: String = ""
        
    func dfs(_ x:Int, _ y: Int, _ dist: Int, _ record:[String]) {
        
        if  k < (dist + minDist(x,y,r,c)) { // 남은 횟수안에 도착 X
            return 
        }
        
        if dist == k && ( x ==  r && y == c ) { 
            ans = record.joined()
            return
        }
        
        for i in 0..<4 {
            
            let dir = dirs[i]
            let (dx, dy) = dir.coord
            
            let nextX = x + dx
            let nextY = y + dy
        
            if  !(1...n ~= nextX) || !(1...m ~= nextY) || !ans.isEmpty { 
                continue
            }
            
            
            dfs(nextX,nextY,dist+1,record + [dir.rawValue])
            
        }
        
       
    }
    
    if  (k < minDist(x,y,r,c)) || (k-minDist(x,y,r,c)) % 2 != 0   { 
        // 맨해튼 거리보다 짧거나 , 그 차이가 홀 수이면 도착 불가 
        return "impossible"
    }
    
    dfs(x,y,0,[])
    
    
    return ans
}
반응형

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

[프로그래머스] n + 1 카드게임  (0) 2024.10.01
[프로그래머스] 산 모양 타일링  (0) 2024.10.01
[프로그래머스] 코딩 테스트 공부  (0) 2024.09.29
[프로그래머스] 파괴되지 않은 건물  (0) 2024.09.29
[프로그래머스] 양과 늑대  (0) 2024.09.29
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 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)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바