[백준] 16194번: 카드 구매하기 2 - Kotlin[코틀린]

2024. 3. 3. 23:26·알고리즘/Baekjoon

문제

 

 

16194번: 카드 구매하기 2

첫째 줄에 민규가 구매하려고 하는 카드의 개수 N이 주어진다. (1 ≤ N ≤ 1,000) 둘째 줄에는 Pi가 P1부터 PN까지 순서대로 주어진다. (1 ≤ Pi ≤ 10,000)

www.acmicpc.net

 


풀이

 

 DP(동적 프로그래밍)으로 해결하는 문제이다. 민규가 카드를 N개를 구매하는 방법은 여러가지가 있으며 다음과 같다.

  - 카드 1개가 포함된 카드팩 + 카드 N-1개 구매: price[1] + dp[N-1]
  - 카드 2개가 포함된 카드팩 + 카드 N-2개 구매: price[2] + dp[N-2]
  - 카드 3개가 포함된 카드팩 + 카드 N-3개 구매: price[3] + dp[N-3]
  ...
  - 카드 M개가 포함된 카드팩 + 카드 N-M개 구매(점화식): $dp[N] = price[M] + dp[N−M]$


 먼저 dp 배열을 해당하는 카드팩을 구매하는 방법으로 초기화하고 이중 반복문을 통 점화식을 활용하여 최소 비용을 찾으면 된다.

 


코드

 

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

    val num = br.readLine().toInt()
    val price = br.readLine().split(' ').map { it.toInt() }
    val dp = IntArray(num+1)

    for(i in 1 .. num) {
        dp[i] = price[i-1]
        for(j in 1 .. i) {
            dp[i] = minOf(dp[i], dp[i - j] + price[j-1])
        }
    }

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

 

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

[백준] 1747번: 소수&팰린드롬 - Kotlin[코틀린]  (0) 2024.03.05
[백준] 1629번: 곱셈 - Kotlin[코틀린]  (0) 2024.03.04
[백준] 11053번: 카드 구매하기 - Kotlin[코틀린]  (0) 2024.03.03
[백준] 2210번: 숫자판 점프 - Kotlin[코틀린]  (1) 2024.03.02
[백준] 1914번: 하노이 탑 - Kotlin[코틀린]  (0) 2024.03.01
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 1747번: 소수&팰린드롬 - Kotlin[코틀린]
  • [백준] 1629번: 곱셈 - Kotlin[코틀린]
  • [백준] 11053번: 카드 구매하기 - Kotlin[코틀린]
  • [백준] 2210번: 숫자판 점프 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

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

    티스토리툴바