우노
[Greedy] 백준 11047번 "동전 0" C++ 풀이 본문
문제 링크
풀이
- 동전 배열을 마지막 idx 부터 역순으로 탐색
- 남은 금액이 해당 idx 의 동전보다 크거나 같다면,
남은 금액에서 해당 idx 금액 만큼을 차감하고 동전 개수 + 1 - 마지막으로 탐색한 idx 부터 1~2번을 반복하며, 남은 금액이 없을 때까지 무한 루프
코드
#include <iostream>
#include <vector>
using namespace std;
vector<int> coin_list;
// 목표 금액까지 몇 개의 동전이 필요한지 출력해주는 함수
int greedy(int remain_cost){
// 목표 금액까지 필요한 동전 개수
int count = 0;
// 동전 배열을 끝에서부터 탐색하기 위한 idx
int idx = coin_list.size()-1;
while (remain_cost != 0){
// 남은 금액이 해당 idx 의 동전보다 크거나 같다면,
// 남은 금액해서 해당 idx 금액 만큼을 차감하고 동전 개수 + 1
if (remain_cost >= coin_list[idx]){
remain_cost -= coin_list[idx];
count += 1;
}
else{
idx -= 1;
}
}
return count;
}
int main(){
// 동전의 종류와 목표 금액 입력
int n, k;
cin >> n >> k;
// 동전
int coin;
// 동전 리스트에 동전 삽입
for (int i=0; i<n; ++i){
cin >> coin;
coin_list.push_back(coin);
}
cout << greedy(k) << endl;
}
'Algorithm > Greedy' 카테고리의 다른 글
[Greedy] 이코테 “큰 수의 법칙” Python 풀이 (0) | 2022.05.30 |
---|---|
[Greedy] 백준 1744번 "수 묶기" C++ 풀이 (0) | 2022.02.15 |
[Greedy] 백준 13305번 "주유소" C++ 풀이 (0) | 2022.02.14 |
[Greedy] 백준 10162번 "전자레인지" C++ 풀이 (0) | 2022.02.14 |
[Greedy] 백준 11000번 "강의실 배정" C++ 풀이 (1) | 2021.12.07 |
Comments