2720번: 세탁소 사장 동혁백준/단계별로 풀어보기2023. 5. 29. 14:03
Table of Contents
문제 출처 : https://www.acmicpc.net/problem/2720
언어 : Kotlin
문제 설명 :
미국으로 유학간 동혁이는 세탁소를 운영하고 있다. 동혁이는 최근에 아르바이트로 고등학생 리암을 채용했다.
동혁이는 리암에게 실망했다.
리암은 거스름돈을 주는 것을 자꾸 실수한다.
심지어 $0.5달러를 줘야하는 경우에 거스름돈으로 $5달러를 주는것이다!
어쩔수 없이 뛰어난 코딩 실력을 발휘해 리암을 도와주는 프로그램을 작성하려고 하지만, 디아블로를 하느라 코딩할 시간이 없어서 이 문제를 읽고 있는 여러분이 대신 해주어야 한다.
거스름돈의 액수가 주어지면 리암이 줘야할 쿼터(Quarter, $0.25)의 개수, 다임(Dime, $0.10)의 개수, 니켈(Nickel, $0.05)의 개수, 페니(Penny, $0.01)의 개수를 구하는 프로그램을 작성하시오. 거스름돈은 항상 $5.00 이하이고, 손님이 받는 동전의 개수를 최소로 하려고 한다. 예를 들어, $1.24를 거슬러 주어야 한다면, 손님은 4쿼터, 2다임, 0니켈, 4페니를 받게 된다.
- 첫째 줄에 테스트 케이스의 개수 T가 주어진다. 각 테스트 케이스는 거스름돈 C를 나타내는 정수 하나로 이루어져 있다. C의 단위는 센트이다. (1달러 = 100센트) (1<=C<=500)
- 각 테스트케이스에 대해 필요한 쿼터의 개수, 다임의 개수, 니켈의 개수, 페니의 개수를 공백으로 구분하여 출력한다.
제한 사항 :
- 시간 제한 : 1초
- 메모리 제한 : 128MB
입출력 예 :
입력 | 출력 |
3 124 25 194 |
4 2 0 4 1 0 0 0 7 1 1 4 |
풀이 :
import java.io.*
fun main(args: Array<String>) {
val br = BufferedReader(InputStreamReader(System.`in`))
val bw = BufferedWriter(OutputStreamWriter(System.out))
val arr = IntArray(4) { 0 }
for (i in 1 .. br.readLine().toInt()) {
val cent = br.readLine().toInt()
arr[0] = cent / 25
arr[1] = (cent % 25) / 10
arr[2] = ((cent % 25) % 10) / 5
arr[3] = (((cent % 25) % 10) % 5) / 1
bw.write("${arr.joinToString(" ")}\n")
}
bw.flush()
bw.close()
}
'백준 > 단계별로 풀어보기' 카테고리의 다른 글
2292번: 벌집 (1) | 2023.05.29 |
---|---|
2903번: 중앙 이동 알고리즘 (0) | 2023.05.29 |
11005번: 진법 변환 2 (0) | 2023.05.29 |
2745번: 진법 변환 (0) | 2023.05.29 |
2563번: 색종이 (0) | 2023.05.26 |
@스몰스테핑 :: 작은 발걸음
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!