鱼C论坛

 找回密码
 立即注册
查看: 2430|回复: 4

[已解决]使用递归编写一个十进制转换为二进制的函数

[复制链接]
发表于 2021-4-21 16:03:03 | 显示全部楼层 |阅读模式
2鱼币
def Dec2Bin(dec):
    result = ''
   
    if dec:
        result = Dec2Bin(dec//2)                  
        return result + str(dec%2)
    else:
        return result

print(Dec2Bin(9))

请大神们指点一下,这个代码没能了解清楚
为什么 Dec2Bin(0) 也就是 dec = 0 的候候,返回值为   ''  了呢?
怎么结果就成了  '' + '1' + '0' + '0' + '1' 呢?


Dec2Bin (9//4) + str (9%2)
                               (1)
Dec2Bin (4//2) + str (4%2)
                               (0)
Dec2Bin (1//2) + str (2%2)
                               (0)
Dec2Bin (0//2) + str (1%2)
                               (1)



刚学到递归不久,希望大神们指点一下




最佳答案
2021-4-21 16:03:04
小桥流水清无鱼 发表于 2021-4-21 16:51
是 result = Dec2Bin(0//2)执行完后,
再次进入def Dec2Bin(0):
然后判断进入dec==0进入else,

不是的,传入参数为0的时候,直接进入else,执行return result,返回空字符串

最佳答案

查看完整内容

不是的,传入参数为0的时候,直接进入else,执行return result,返回空字符串
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-4-21 16:03:04 | 显示全部楼层    本楼为最佳答案   
小桥流水清无鱼 发表于 2021-4-21 16:51
是 result = Dec2Bin(0//2)执行完后,
再次进入def Dec2Bin(0):
然后判断进入dec==0进入else,

不是的,传入参数为0的时候,直接进入else,执行return result,返回空字符串
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-4-21 16:11:43 | 显示全部楼层
因为 dec == 0 的时候代码不满足 if 所以直接执行 else
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-4-21 16:51:00 | 显示全部楼层
qq1151985918 发表于 2021-4-21 16:11
因为 dec == 0 的时候代码不满足 if 所以直接执行 else

是 result = Dec2Bin(0//2)执行完后,
再次进入def Dec2Bin(0):
然后判断进入dec==0进入else,
然后return result 拿上面的result = ''
然后回去一个个返回这样子吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-4-21 21:23:38 | 显示全部楼层
昨非 发表于 2021-4-21 17:10
不是的,传入参数为0的时候,直接进入else,执行return result,返回空字符串

懂了懂了,谢谢啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 08:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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