python找零钱_python---通过递归和动态规划策略解决找零钱问题

也是常见套路。

# coding = utf-8

def rec_mc(coin_value_list, change, know_results):

min_coins = change

if change in coin_value_list:

know_results[change] = 1

return 1

elif know_results[change] > 0:

return know_results[change]

else:

for i in [c for c in coin_value_list if c <= change]:

num_coins = 1 + rec_mc(coin_value_list, change-i, know_results)

if num_coins < min_coins:

min_coins = num_coins

know_results[change] = min_coins

return min_coins

print("===========递归实现========================")

print(rec_mc([1, 5, 10, 25], 63, [0]*64))

def dp_make_change(coin_value_list, change, min_coins, coins_used):

for cents in range(change+1):

coin_count = cents

new_coin = 1

for j in [c for c in coin_value_list if c <= cents]:

if min_coins[cents-j] + 1 < coin_count:

coin_count = min_coins[cents-j]+1

new_coin = j

min_coins[cents] = coin_count

coins_used[cents] = new_coin

return min_coins[change]

def print_coins(coins_used, change):

coin = change

while coin > 0:

this_coin = coins_used[coin]

print(this_coin)

coin = coin - this_coin

a_mnt = 63

c_list = [1, 5, 10, 21, 25]

c_used = [0] * (a_mnt+1)

c_count = [0] * (a_mnt+1)

print("===========动态规划实现========================")

print('Making change for ', a_mnt, 'requires')

print(dp_make_change(c_list, a_mnt, c_count, c_used), 'coins')

print("They are: ")

print_coins(c_used, a_mnt)

print("The used list is as follows: ")

print(c_used)

输出:

D:\cheng\test\Scripts\python.exe tests.py

===========递归实现========================

6

===========动态规划实现========================

Making change for 63 requires

3 coins

They are:

21

21

21

The used list is as follows:

[1, 1, 1, 1, 1, 5, 1, 1, 1, 1, 10, 1, 1, 1, 1, 5, 1, 1, 1, 1, 10, 21, 1, 1, 1, 25, 1, 1, 1, 1, 5, 10, 1, 1, 1, 10, 1, 1, 1, 1, 5, 10, 21, 1, 1, 10, 21, 1, 1, 1, 25, 1, 10, 1, 1, 5, 10, 1, 1, 1, 10, 1, 10, 21]

Process finished with exit code 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值