알고리즘 문제풀이
Swea D2_1970. 쉬운 거스름돈 Python 그리디
아크몽
2024. 3. 3. 23:19
각 동전간 배수 관계 => 그리디 형식으로, 가장 큰 동전부터 빼는 작업이 가능함
정답 코드 : for문 사용
arr = [50000, 10000, 5000, 1000, 500, 100, 50, 10]
t= int(input())
for tc in range(1,t+1):
n = int(input())
cnt = [0] * 8
for i in range(8):
if n // arr[i] >0:
cnt[i] += n // arr[i]
n = n % arr[i]
print(f'#{tc}')
print(*cnt)
틀린 코드 while 사용 으로 런타임 오류로 2/10 개 맞춤
arr = [50000, 10000, 5000, 1000, 500, 100, 50, 10]
t= int(input())
for tc in range(1,t+1):
n = int(input())
cnt = [0] * 8
i = 0
while n >0 or i <= 7:
if n >= arr[i]:
n -= arr[i]
cnt[i] += 1
else:
i += 1
print(f'#{tc}')
print(*cnt)