校招真题练习013 找零(头条)

找零

题目描述
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)

算法思路:贪心法

原文地址:https://www.cnblogs.com/asenyang/p/11100614.html