QQ登录

只需一步,快速开始

登录 | 立即注册 | 找回密码

主题

帖子

荣誉

VIP至尊会员

Rank: 15Rank: 15Rank: 15

积分
35
查看: 115|回复: 2

[已解决]关于递归的小问题

[复制链接]
最佳答案
0 
累计签到:21 天
连续签到:14 天
xia兄弟 发表于 2018-2-13 21:58:59 1152 | 显示全部楼层 |阅读模式
2鱼币
def Dec2Bin(dec):
    result = ''
   
    if dec:
        result = Dec2Bin(dec//2)
        return result + str(dec%2)
    else:
        return result

print(Dec2Bin(62))


哪位大神指导指导呀,帮忙解读一下这个递归
最佳答案
2018-2-13 21:59:00
就你这一段代码说明一下:
函数Dec2Bin(62)运行后返回 Dec2Bin(31) + str(0)
而 Dec2Bin(31) 的返回值是 Dec2Bin(15) + str(1),所以 Dec2Bin(62) 返回的就变成了 Dec2Bin(15) + str(1) + str(0)
一直递归下去直到 dec = 0,此时 Dec2Bin(0) 返回的是 '',所以整个函数的返回值就是  '' +...+ str(1) + str(0) 。

最佳答案

查看完整内容

就你这一段代码说明一下: 函数Dec2Bin(62)运行后返回 Dec2Bin(31) + str(0) 而 Dec2Bin(31) 的返回值是 Dec2Bin(15) + str(1),所以 Dec2Bin(62) 返回的就变成了 Dec2Bin(15) + str(1) + str(0) 一直递归下去直到 dec = 0,此时 Dec2Bin(0) 返回的是 '',所以整个函数的返回值就是 '' +...+ str(1) + str(0) 。
楼层
跳转到指定楼层
最佳答案
146 
累计签到:96 天
连续签到:66 天
°蓝鲤歌蓝 发表于 2018-2-13 21:59:00 | 显示全部楼层    本楼为最佳答案   
就你这一段代码说明一下:
函数Dec2Bin(62)运行后返回 Dec2Bin(31) + str(0)
而 Dec2Bin(31) 的返回值是 Dec2Bin(15) + str(1),所以 Dec2Bin(62) 返回的就变成了 Dec2Bin(15) + str(1) + str(0)
一直递归下去直到 dec = 0,此时 Dec2Bin(0) 返回的是 '',所以整个函数的返回值就是  '' +...+ str(1) + str(0) 。
最佳答案
9 
累计签到:159 天
连续签到:29 天
御笔剑客 发表于 2018-2-14 00:13:31 | 显示全部楼层
功能是十进制转二进制,过程大致就是楼上那样

发表回复

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

本版积分规则

关闭

小甲鱼强烈推荐 上一条 /2 下一条

    移动客户端下载(未启用)
    微信公众号

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备11014136号

Copyright 2018 鱼C论坛 版权所有 All Rights Reserved.

Powered by Discuz! X3.1 Copyright
© 2001-2018 Comsenz Inc.    All Rights Reserved.

小黑屋|手机版|Archiver|鱼C工作室 ( 粤公网安备 44051102000370号 | 粤ICP备11014136号

GMT+8, 2018-2-26 11:36

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