[백준] 1520 내리막 길

2024. 10. 11. 23:19·PS/백준
반응형

 

문제

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

 

입력

n, m = 지도의 행 , 열 길이 
arr: [[Int]] = 각 지점의 높이

결과

ans: Int = 이동 가능한 총 경로 수

해석

내리막길인지 판별한후 dfs를 통해 목적지에 도달 후 return을 통해 카운팅을 해주자.

 

 

코드

import Foundation

let nm = readLine()!.components(separatedBy: " ").map{Int($0)!}

let (n,m) = (nm[0], nm[1])

var arr: [[Int]] = []

for _ in 0..<n {
    arr.append(readLine()!.components(separatedBy: " ").map{Int($0)!})
}

var cache: [[Int]] = [[Int]](repeating: [Int](repeating: -1, count: m), count: n)

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

func dfs(_ x: Int,_ y: Int) -> Int {
    
    if x == n-1 && y == m-1 {
        cache[x][y] = 1
        return 1
    }
    
    if cache[x][y] != -1 { // 이전에 도착한 기록이 있음
        return cache[x][y]
    }
    
    cache[x][y] = 0
    
    for i in 0..<4 {
        let nx = x + dx[i]
        let ny = y + dy[i]
        
        if !(0..<n ~= nx) || !(0..<m ~= ny) { continue }
        
        // 내리막길이 아님
        if arr[x][y] <= arr[nx][ny] { continue }
        
        // 내리막길이므로 다음으로 구간으로
        cache[x][y] += dfs(nx, ny)
        
    }
    
    return cache[x][y]
    
}

print(dfs(0, 0))

 

반응형

'PS > 백준' 카테고리의 다른 글

[백준] 15486 퇴사 2  (0) 2024.10.13
[백준] 11722 가장 긴 감소하는 부분 수열  (0) 2024.10.13
[백준] 2294 동전 2  (2) 2024.10.10
[백준] 2293 동전 1  (0) 2024.10.09
[백준] 9251 LCS  (1) 2024.10.09
'PS/백준' 카테고리의 다른 글
  • [백준] 15486 퇴사 2
  • [백준] 11722 가장 긴 감소하는 부분 수열
  • [백준] 2294 동전 2
  • [백준] 2293 동전 1
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (304)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (37)
        • swift (32)
        • python (4)
        • Kotlin (1)
      • iOS (132)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (32)
        • 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 (13)
        • 어노테이션 (1)
        • 튜토리얼 (11)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (0)
        • 이론 (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[백준] 1520 내리막 길
상단으로

티스토리툴바