找零兑换问题:递归解法

本文通过递归解决找零兑换问题,详细阐述递归的三个定律,并结合美元硬币体系实例,展示如何减少问题规模。原始算法效率低下,针对63分兑换需要67716925次递归。通过改进算法,利用表存储中间结果避免重复计算,63分问题的递归调用次数降至221次,显著提升了效率。
摘要由CSDN通过智能技术生成

引言

用递归解决找零兑换问题,首先先要明确递归三定律
1.最小规模问题(基本结束条件)
2.减小问题规模(向结束条件演进)
3.解决减小了规模的相同问题(调用自身)

应用到实际找零兑换的问题上,首先明确最小规模问题:需要兑换的找零,其面值正好等于某种硬币。如我们需要找零25分,刚好有25分面值的硬币,这里就只需要1个硬币就可完成找零。
在这里插入图片描述
其次是减小问题的规模:对每种硬币的面值分别尝试。
如美元硬币体系:找零减去1分(penny)、5分(nikel)、10分(dime)、25分(quarter)后求兑换硬币的最少数量(递归调用自身)
选则上述减小规模次数最小的方案完成找零
在这里插入图片描述

代码如下

import time

def recMC(coinValueList, change):
    mincoin = change
    #最小规模问题,如果找零刚好有面值相等的硬币即返回1
    if change in coinValueList:
        return 1
    else:
        #减小问题规模,将每种情况都试完,选择找零需要的最小硬币数
        for i in 
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值