我怎么写这个?
编写一个完整的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)
答案 0 :(得分:1)
这应该计算所需的不同类型硬币的数量:
a=int(input("Enter amount: ")) #Ask for amount
q = a // 25 #Calculate number of quarters
a -= q*25 #Subtract value of quarters
d = a // 10 #Calculate number of dimes
a -= d*10 #Subtract value of dimes
n = a // 5 #Calculate number of nickels
a -= n*5 #Subtract value of nickels
p = a #Calculate number of pennies
print ("Quarters :" + str(q))
print ("Dimes :" + str(d))
print ("Nickels :" + str(n)) #Print out numbers of coins
print ("Pennies :" + str(p))
首先询问金额,然后计算所需的季度数,然后减去需要的季度金额
答案 1 :(得分:1)
一个贪婪的算法可以正常工作(因为硬币面额)(也就是说,你总是可以采用最小面额,而不是总面额,最终得到最佳解决方案)
def get_next(self,change_due):
next_coin = max(x for x in [1,5,10,25] if x <= change_due)
return change_due-next_coin,next_coin
change_due = 99
coins = []
while change_due > 0:
change_due,next_coin = get_next(change_due)
coins.append(next_coin)
print coins
所有这些说你也可以像其他答案一样用数学解决。还值得注意的是,如果你有一个7美分硬币,这个解决方案将不再为你提供最佳解决方案(但另一个也不会)