[백준] 2579번: 계단 오르기 - Kotlin[코틀린]

2023. 9. 21. 22:21·알고리즘/Baekjoon

문제

 

 

2579번: 계단 오르기

계단 오르기 게임은 계단 아래 시작점부터 계단 꼭대기에 위치한 도착점까지 가는 게임이다. <그림 1>과 같이 각각의 계단에는 일정한 점수가 쓰여 있는데 계단을 밟으면 그 계단에 쓰여 있는 점

www.acmicpc.net

 


풀이

 

 점화식을 만들기 위해 문제에서 주어진 규칙을 보면,

 

 1. 계단은 한번에 한 계단, 두 계단씩 오를 수 있다.

 2. 연속된 3개의 계단을 밟으면 안된다.

 

 이 규칙에서 현재 계단 N을 밟기 위한 방법으로는 N - 2에서 N까지 두 계단 이동한 경우와 N - 3에서 N - 1까지 두 계단 이동하고 N - 1에서 N까지 한 계단 이동한 경우로 2가지만 가능하다.

 연속해서 3개의 계단을 밟는 것이 불가능하기 때문에 위의 두 가지 방법이 전부가 된다. 그렇다면 현재 계단에서의 점수의 최대값은 위의 두가지 방법 중 더 큰 경우의 수 더하기 현재 계단의 값이 된다. 따라서 점화식은 dp[N] = max(dp[N - 2], dp[N - 3] + arr[ - 1]) + arr[N] 이 된다.

 

 첫번째 계단과 두번째 계단은 무조건 밟는 경우가 최대값이기 때문에 각각 값을 대입해두고 반복문을 통해 dp 계산을 하면 된다.

 


코드

 

import kotlin.math.*

fun main() {
    val br = System.`in`.bufferedReader()
    val bw = System.out.bufferedWriter()

    val num = br.readLine().toInt()
    val dp = IntArray(num+1)
    val arr = IntArray(num){ br.readLine().toInt() }

    dp[1] = arr[0]
    if(num > 1) { // num에 1이 입력될 수 있기 때문에 예외처리 해준다.
        dp[2] = arr[0] + arr[1]
    }
    for(i in 3 .. num) {
        dp[i] = max(dp[i - 2], dp[i - 3]+ arr[i - 2]) + arr[i - 1]
    }

    bw.write("${dp[num]}")
    bw.flush()
    bw.close()
    br.close()
}

 

'알고리즘 > Baekjoon' 카테고리의 다른 글

[백준] 10971번: 외판원 순회 2 - Kotlin[코틀린]  (0) 2023.09.24
[백준] 1931번: 회의실 배정 - Kotlin[코틀린]  (0) 2023.09.23
[백준] 9095번: 1, 2, 3 더하기 - Kotlin[코틀린]  (0) 2023.09.21
[백준] 11050번: 이항 계수 1 - Kotlin[코틀린]  (0) 2023.09.20
[백준] 11401번: 이항 계수 3 - Kotlin[코틀린]  (0) 2023.09.18
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 10971번: 외판원 순회 2 - Kotlin[코틀린]
  • [백준] 1931번: 회의실 배정 - Kotlin[코틀린]
  • [백준] 9095번: 1, 2, 3 더하기 - Kotlin[코틀린]
  • [백준] 11050번: 이항 계수 1 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      누적 합
      구현
      분할 정복
      dfs
      우선순위 큐
      스택
      티스토리
      DP
      큐
      브루트포스
      소수 판정
      수학
      BFS
      모듈러 곱셈 역원
      투 포인터
      크루스칼
      유니온파인드
      에라토스테네스의 체
      그래프이론
      피보나치
      MST
      정렬
      그리디
      분리집합
      프림
      이분 탐색
      그래프 탐색
      백트래킹
      재귀
      문자열
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 2579번: 계단 오르기 - Kotlin[코틀린]
    상단으로

    티스토리툴바