换零钱方式的统计

question:给了半美元,四分之一美元,10每分,5美分和1美分的硬币,将一美元换成零钱,一共有多少种不同方式?
更一般的问题是,给定了任意数量的现金,我们能写出一个程序,计算出所有换零钱的种数吗?
answer:
采用递归程序,这一问题有一种很简单的解法.假定我们所考虑的可用硬币类型种类排了某种顺序,于是就有下面的关系:
将总数为a的现金换成n中硬币的不同方式的数目等于:
将现金数a换成除第一种硬币之外的所有其他硬币的不同方式数目,加上
将现金数a-d换成所有种类的硬币的不同方式数目,其中d是第一种硬币的币值.

(define (count-change amount)
  (cc amount 5))
(define (cc amount kinds-of-coins)
  (cond ((= amount 0) 1)
        ((or (< amount 0)
             (= kinds-of-coins 0)) 0)
        (else (+ (cc amount (- kinds-of-coins 1))
                 (cc (- amount (first-denomination kinds-of-coins)) kinds-of-coins)))))
(define (first-denomination kinds-of-coins)
  (cond ((= kinds-of-coins 1) 1)
        ((= kinds-of-coins 2) 5)
        ((= kinds-of-coins 3) 10)
        ((= kinds-of-coins 4) 25)
        ((= kinds-of-coins 5) 50)))

(count-change 100)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
任务悬赏源码活动营销三级分销返佣积分商城版 这个是带有VUE源码的搭建也是很简单可生成APP 功能说明: 分销功能:用户拉新用户做任务可以获取任务返佣,三级分销逻辑。 用户拉新会员可以获取一定比例的返佣,根据会员的等级不同获取返佣的比例不同。 会员功能:会员可以根据不同的等级设置任务返佣比例,以及提现手续费和发布任务置顶次数的赠送问题。会员做任务的价格与普通用户做任务的返佣不同。 任务设置:包含非会员每日领取设置、放弃任务领取功能设置、任务审核时间后台自定义设置、普通用户任务返佣设置。 联盟配置:联盟功能接口已测试完善,并实现线上收益,每个平台管理只需要申请联盟账户即可对接联盟相关的任务。分为为8/2分配。 其他设置:包含最低提现设置,最低单个任务发布佣金设置、每日提现次数设置、任务信用分设置,完成不了任务信誉分降低等问题配置。 积分商城:赚积分可在商城里兑换平台的一些礼品等,提高了用户粘性,为平台增加了更多的亮点。 统计相关:包含联盟的财务统计,任务反馈统计。用户财务统计,以及平台数据分析。 用户管理:后台可在线为用户充值,积分明细、任务明细、资金明细一目了然。便于平台管理。 任务分类:后台根据分类调用到幻灯片任务接口。自定义任务分类名称和任务导航图片。 任务管理:包含平台的任务列表和用户任务列表,以及任务订单的相关管理。 提现充值: 在这个问题上做了区分处理。根据用户的资质问题,有很多商户没有企业支付到零钱的功能,前期可以设置为手动提现,如果有企业支付到零钱功能可以设置为自动提现。提现列表里普通提现为二维码转账给任务用户,商家自动提现可以直接转账到用户微信钱包。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值