鱼C论坛

 找回密码
 立即注册
查看: 2059|回复: 5

[已解决]递归好懵啊!!!

[复制链接]
发表于 2021-6-13 17:45:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
def Dec2Bin(dec):
    result = ''
    
    if dec:
        result = Dec2Bin(dec//2)
        return result + str(dec%2)
    else:
        return result

这段代码怎么理解的啊?特别是递归部分
最佳答案
2021-6-13 20:24:33
本帖最后由 洛阳城 于 2021-6-14 16:46 编辑

这是一个十进制转二进制的程序,函数的功能是传入一个十进制数dec将自动计算对应的二进制数并返回
def Dec2Bin(dec):
    result = ''  # 定义一个字符串变量保存结果

    if dec:  # 如果传入的参数大于0
        result = Dec2Bin(dec // 2)  # 递归计算,‘//’是整数除法,其结果等于除法计算结果向下取整
        return result + str(dec % 2)  # 将计算得到的余数进行拼接并返回
    else:
        return result  # 当传入的参数等于0时,返回计算得结果
  分析代码可以得知,当传入一个非0参数时,程序将不断递归计算该参数对2整除的结果直到该结果等于0,当结果等于0时将执行第8行代码,返回result的值,于是程序将会自动查找result最后一次赋值的结果,也就是第5行;但是第5行又涉及到了函数的调用,需要获取该次调用的返回值,也就是第6行代码,于是程序将在此不断回溯前面的计算结果并进行拼接,也就是倒着求前面每次(dec//2)的结果对2的余数并且拼接起来,直到dec等于传入值后,再次回溯result将等于第2行的none,此时if为假,返回此时的结果
  具体过程建议楼主在第4行处设置一个断点然后debug单步执行观察整个代码的运行过程,dec不要设置的太大就好,否则步骤会很多点起来会很累
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-6-13 20:24:33 | 显示全部楼层    本楼为最佳答案   
本帖最后由 洛阳城 于 2021-6-14 16:46 编辑

这是一个十进制转二进制的程序,函数的功能是传入一个十进制数dec将自动计算对应的二进制数并返回
def Dec2Bin(dec):
    result = ''  # 定义一个字符串变量保存结果

    if dec:  # 如果传入的参数大于0
        result = Dec2Bin(dec // 2)  # 递归计算,‘//’是整数除法,其结果等于除法计算结果向下取整
        return result + str(dec % 2)  # 将计算得到的余数进行拼接并返回
    else:
        return result  # 当传入的参数等于0时,返回计算得结果
  分析代码可以得知,当传入一个非0参数时,程序将不断递归计算该参数对2整除的结果直到该结果等于0,当结果等于0时将执行第8行代码,返回result的值,于是程序将会自动查找result最后一次赋值的结果,也就是第5行;但是第5行又涉及到了函数的调用,需要获取该次调用的返回值,也就是第6行代码,于是程序将在此不断回溯前面的计算结果并进行拼接,也就是倒着求前面每次(dec//2)的结果对2的余数并且拼接起来,直到dec等于传入值后,再次回溯result将等于第2行的none,此时if为假,返回此时的结果
  具体过程建议楼主在第4行处设置一个断点然后debug单步执行观察整个代码的运行过程,dec不要设置的太大就好,否则步骤会很多点起来会很累
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-6-13 22:07:00 | 显示全部楼层
根据其代码,先试验最初几个值:
Dec2Bin(0) = ''
Dec2Bin(1) = Dec2Bin(0) + str(1%2) = '' + '1'  --> '1'
Dec2Bin(2) = Dec2Bin(1) + str(2%2) = '1' + '0' --> '10'
Dec2Bin(3) = Dec2Bin(1) + str(3%2) = '1' + '1'  --> '11'
……

OK?

ps: 注意 dec // 2 的 // 是“地板除”(向下取整),具体理解自己多试几个,就明白了。

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-6-14 15:32:23 | 显示全部楼层
洛阳城 发表于 2021-6-13 20:24
这是一个十进制转二进制的程序,函数的功能是传入一个十进制数dec将自动计算对应的二进制数并返回

  分 ...

是不是说,就是把 string = decbin(n//2) 这个调用自身的行为全部载入内存,直到n=0时,再按照最后载入的顺序反向写出?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-6-14 15:51:18 | 显示全部楼层
sc-tbm 发表于 2021-6-14 15:32
是不是说,就是把 string = decbin(n//2) 这个调用自身的行为全部载入内存,直到n=0时,再按照最后载入的 ...

整个过程大致是这样的,但是按照载入的顺序反向写出是因为函数返回值的赋值涉及到了递归调用
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-6-14 16:08:57 | 显示全部楼层
洛阳城 发表于 2021-6-14 15:51
整个过程大致是这样的,但是按照载入的顺序反向写出是因为函数返回值的赋值涉及到了递归调用

了解了,递归本身就是先把自身调用到没有可调用的情况后再按照最后一次调用为第一个值得形式逐一输出
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-15 13:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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