https://www.acmicpc.net/problem/11047
11047번: 동전 0
첫째 줄에 N과 K가 주어진다. (1 ≤ N ≤ 10, 1 ≤ K ≤ 100,000,000) 둘째 줄부터 N개의 줄에 동전의 가치 Ai가 오름차순으로 주어진다. (1 ≤ Ai ≤ 1,000,000, A1 = 1, i ≥ 2인 경우에 Ai는 Ai-1의 배수)
www.acmicpc.net
<내 코드>
- 입력 받은 동전 coins를 내림차순으로 정렬했다. (큰 동전부터 파악해야 최소 갯수로 k원 만들 수 있기 때문에)
- 반복문을을 돌면서 만약 k // coins[i] > 0 이라면 즉, 몫이 있다면 cnt에 몫을 저장해주고, k는 나머지로 업데이트한다.
import sys
input = sys.stdin.readline
n, k = map(int, input().split())
coins = []
for _ in range(n):
coins.append(int(input()))
coins.sort(reverse = True) #내림 차순 정렬
cnt = 0
for i in range(n):
if k // coins[i] > 0:
cnt += k// coins[i]
k = k % coins[i]
print(cnt)
'알고리즘 > 그리디' 카테고리의 다른 글
[백준-실버4] 2217번 로프 (그리디, 파이썬) (0) | 2022.03.05 |
---|---|
[백준-실버4] 1026번 보물 (그리디, 파이썬) (0) | 2022.03.04 |
[백준-실버2] 1541번 잃어버린 괄호 (그리디, 파이썬) (0) | 2022.03.04 |
[백준-실버4] 13305번 주유소 (그리디, 파이썬) (0) | 2022.03.04 |
[백준-실버2] 1931번 회의실 배정(그리디, 파이썬) (0) | 2022.03.04 |