查看: 1124| 回复: 1
收起左侧

[学Python/Perl] 凑硬币题

|只看干货
zyq | 显示全部楼层 |阅读模式
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (14)
 
 
0% (0)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
初学python,一道题目如下: 用 1, 5, 10, 25美分凑1美元,问有多少种凑法(242种) 。答案用generator写的,确认能跑出答案。但我对第二个for loop不太明白,为啥又在make_change函数里loop了呢? 没见过这种操作,有高手能给说说吗


def make_change(amount, coins=[1,5,10,25], hand=None):
    hand=[] if hand is None else hand
    if  amount==0:
        yield hand
    for coin in coins:
        if coin > amount or (len(hand)>0 and hand[-1] < coin):
            continue
        
        for result in make_change(amount-coin, coins=coins, \
                                  hand=hand+[coin]):
            yield result
            
            
for way in make_change(100,coins=[1,5,10,25], hand=None):
    print(way)


ggg.pdf

70.39 KB, 下载次数: 2, 下载积分: 大米 -1 颗

code


上一篇:求问leetcode 1011. Capacity To Ship Packages Within D Days怎么想到二分法?
下一篇:关于Java的protect关键字
 楼主| zyq 2020-12-20 01:32:38 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (14)
 
 
0% (0)    👎
重新调整代码格式

  1. def make_change(amount, coins=[1,5,10,25], hand=None):
  2.     hand=[] if hand is None else hand
  3.     if  amount==0:
  4.         yield hand
  5.     for coin in coins:
  6.         if coin > amount or (len(hand)>0 and hand[-1] < coin):
  7.             continue
  8.         
  9.         for result in make_change(amount-coin, coins=coins, \
  10.                                   hand=hand+[coin]):
  11.             yield result
  12.             
  13.             
  14. for way in make_change(100,coins=[1,5,10,25], hand=None):
  15.     print(way)
复制代码
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表