我怎么写这个?
编写一个完整的python程序,允许用户输入0到99之间的数字,代表美分 . 然后程序会告诉你需要多少个四分之一,一角硬币,一分钱和几分钱来改变这个整数 . 例如,输出92将输出
这是我到目前为止所写的,我已经习惯了Java,所以我认为我混合了一些Java元素
a=(int(input("amount")
int p = 0
int n = 0
int d = 0
int q = 0
if(a % 10 != 5)
p = (a % 10)
a -= p
q = a / 25
a -= q * 25
d = a / 10
a -= d * 10
n = a / 5
a -= n * 5
print ("Quarters :" + q)
print ("Dimes :" + d)
print ("Nickels :" + n)
print ("Pennies :" + p)
2 回答
这应该计算所需的不同类型硬币的数量:
它首先询问金额,然后计算所需的季度数,然后减去需要的季度金额
一个贪婪的算法可以正常工作(因为硬币面额)(也就是说,你可以总是采用最小面额而不是总面额并最终获得最佳解决方案)
所有这些说你也可以像其他答案一样用数学解决 . 它还值得注意的是,如果你有一个7美分硬币,这个解决方案将不再给你最佳的解决方案(但另一个不会)