[백준] 2293 동전 1

2024. 10. 9. 20:12·PS/백준
반응형

문제

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

 

입력

n = 동전의 종류 (1~100)
k = 목표 금액 (1~10,000)

coins = 각 동전 금액

결과

ans: Int = k 목표 금액을 만들 수 있는 경우의 수

해석

dp를 통한 경우의 수를 카운팅하는 문제 느낌이다.

 

dp 배열의 규칙은 다음과 같다.

 

dp[i] = i원을 만들 수 있는 경우의 수 

 

 dp 배열을 저렇게 잡으면 점화식은 이렇게 따오를 것 같다

 

C를 만들기 위해 B는 동전 A가 부족한 상황이면

dp[c] = dp[b] + dp[a] 상황이다.

코드

import Foundation

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

let (n,k) = (nk[0], nk[1])

var coins: [Int] = []

var dp: [Double] = [Double](repeating: 0, count: k+1)



for _ in 0..<n {
    let coin = Int(readLine()!)!
    coins.append(coin)
}

dp[0] = 1 // 0원을 만드는 경우의 수는 1

for coin in coins { // 모든 동전을 순회
    
    if coin > k { continue } // 현재 동전이 목표 값 k보다 크다면 의미 없음
    
    for i in 0...k-coin {
        dp[i+coin] += dp[i] //  i+coin을 만들기위해서는 dp[i]와 coin이 필요하므로, dp[i]의 경우의 수를 누적한다.
    }
}

print(Int64(dp[k]))

 

반응형

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

[백준] 15486 퇴사 2  (0) 2024.10.13
[백준] 11722 가장 긴 감소하는 부분 수열  (0) 2024.10.13
[백준] 1520 내리막 길  (1) 2024.10.11
[백준] 2294 동전 2  (2) 2024.10.10
[백준] 9251 LCS  (1) 2024.10.09
'PS/백준' 카테고리의 다른 글
  • [백준] 11722 가장 긴 감소하는 부분 수열
  • [백준] 1520 내리막 길
  • [백준] 2294 동전 2
  • [백준] 9251 LCS
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)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[백준] 2293 동전 1
상단으로

티스토리툴바