일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 |
Tags
- 스탠실 버퍼 튜토리얼
- 스탠실 버퍼 시작
- html
- node.js
- unity stencil buffer
- Expo
- react native accessible
- 리액트 네이티브 맥
- react native typescript navigate
- react native typescript navigation
- GitHub
- 스탠실 버퍼 사용
- node
- react native 타입스크립트
- stencil buffer
- 벡터와 리스트의 차이
- c++ 정보은닉
- react
- c++ using
- react native typescript
- cyworld
- react-native
- C++
- CSS
- react native ios 기기 연결
- 리액트 네이티브 설치 오류
- javascript
- react native
- react native mac
- 싸이월드
Archives
- Today
- Total
혀니의 이거저거 뿌시기
11047 코인 본문
728x90
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
N,K = map(int, input().split())
temp = []
result = 0
for i in range(N):
temp.append(int(input()))
for i in range(N - 1, -1, -1):
if K // temp[i] >= 1:
result += K // temp[i]
K -= K // temp[i] * temp[i]
elif K == 0:
break
print(result)
그리디에 가장 대표적인 문제로 가장 적은 수로 거스름돈을 주는 방법을 찾는 문제이다
우선 이 문제에서는 가장 큰 동전부터 기존 값에서 빼나가면서 수를 더해야 한다.
이 때, range를 큰수에서 작은수로 가게 하고 싶을 때에는 range(N-1, -1, -1)형태로 사용해야하는데
만일 가운데 값을 0으로 지정하면 1까지만 참조하기 때문에 0 인덱스까지 참조하고 싶다면 -1이라고 써야 한다.
728x90
'알고리즘 공부(C++)' 카테고리의 다른 글
1436 영화감독 숌 (0) | 2022.08.11 |
---|---|
1966 프린터 큐 (0) | 2022.08.10 |
10773 제로 (0) | 2022.08.09 |
7568 덩치 (0) | 2022.08.08 |
11399 ATM (0) | 2022.08.06 |