C로 구현한 5585번 거스름돈 구하기 문제 풀이입니다.
https://www.acmicpc.net/problem/5585
#include <stdio.h>
int main() {
int input, money, result=0;
scanf("%d", &input);
money = 1000 - input;
result += money / 500;
money %= 500;
result += money / 100;
money %= 100;
result += money / 50;
money %= 50;
result += money / 10;
money %= 10;
result += money / 5;
money %= 5;
result += money / 1;
printf("%d", result);
}
우선 문제 조건에 1000엔 지폐를 한장 냈을 때 라는 조건이 걸려있고, 거스름돈을 내어주기 위해 변수 money에
1000엔 - input(지불한 금액) 을 계산하여 저장한다. 그럼 money 변수는 거스름돈 변수에 해당한다.
변수 result에 먼저 500을 나눈 몫을 저장한 다음 100을 나눈 몫을 누적시키고, 50을 나눈 몫을 누적시키고, 10을 나눈 몫을
누적시키고, 5를 나눈 몫을 누적시키고 마지막으로 1을 나눈 몫을 누적시키면 된다.
즉, 만약 380엔을 입력시킨다고 가정한다면 거슬러줘야하는 금액은 1000-380 = 620엔이다.
또한 거스름돈에 포함된 매수를 구하는 과정은 아래와 같다.
(1) 620에서 500을 나눈 몫은 1이고 나머지 값은 120이다.
(2) 120에서 100을 나눈 몫은 1이고 나머지 값은 20이다.
(3) 20에서 10을 나눈 몫은 2이고 나머지 값은 0이다.
=> 그러므로 총 몫을 누적해나가면 1 + 1 + 2 = 4 라는 결과를 얻을 수 있다.
'백준(C언어) 풀이 > 그리디(Greedy) 알고리즘' 카테고리의 다른 글
백준(C) 2437번 저울 풀이 (0) | 2021.08.06 |
---|---|
백준(C) 2217번 로프 풀이 (0) | 2021.08.03 |
백준(C++) 2217번 로프 풀이 (0) | 2021.08.03 |
백준(C) 11399번 ATM 풀이 (0) | 2021.08.03 |
백준(C) 11047번 동전 0 풀이 (0) | 2021.08.03 |