题目描述
Z国的货币系统包含面值1元、4元、16元、64元共计4种硬币,以及面值1024元的纸币。现在小Y使用1024元的纸币购买了一件价值为
N(0<N≤1024)的商品,请问最少他会收到多少硬币?
输入描述:
一行,包含一个数N。
输出描述:
一行,包含一个数,表示最少收到的硬币数。
1 N = int(input()) 2 N = 1024 - N 3 cnt = 0 4 dic = [64,16,4,1] 5 i = 0 6 while i < 4 and N > 0: 7 j = 0 8 while dic[i] * j <= N: 9 j += 1 10 N = N - dic[i] * (j-1) 11 cnt += j-1 12 i += 1 13 print(cnt)
算法思路:贪心法