백준 알고리즘/Lang-node.js

[백준/node.js] 5585번 거스름돈

Jongung 2022. 3. 18. 23:43

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

 

5585번: 거스름돈

타로는 자주 JOI잡화점에서 물건을 산다. JOI잡화점에는 잔돈으로 500엔, 100엔, 50엔, 10엔, 5엔, 1엔이 충분히 있고, 언제나 거스름돈 개수가 가장 적게 잔돈을 준다. 타로가 JOI잡화점에서 물건을 사

www.acmicpc.net

 

  • 사용언어 : node.js
  • 알고리즘 : 그리디 알고리즘
  • Solved.ac Tier : Bronze II

 

node.js 코드

1. 문제 정리

알고리즘을 다시 시작하며, 그리디 알고리즘부터 천천히 풀어나가보기로 했다. 그리디의 기본인 거스름 돈 문제부터 보자.

JOI잡화점엔 잔돈으로 500원,100원,10원,5원,1원이 있다고 한다. 언제나 거스름돈을 적게 주는 알고리즘을 짜라는 문제이다.

하나하나 비교해가주며 while문을 돌려주었다.

2. 완성 코드

const fs = require('fs');
let inputs = fs.readFileSync("/dev/stdin").toString();
let answer = 0, input = 1000 - inputs;

while(input >= 500){
    input -= 500;
    answer++;
}
while(input >= 100){
    input -= 100;
    answer++;
    
}
while(input >= 50){
    input -= 50;
    answer++;
}
while(input >= 10){
    input -= 10;
    answer++;
}
while(input >= 5){
    input -= 5;
    answer++;
}
while(input >= 1){
    input -= 1;
    answer++;
}



console.log(answer);