鱼C论坛

 找回密码
 立即注册
查看: 4038|回复: 27

用递归将十进制转为二进制

[复制链接]
发表于 2018-4-2 13:49:26 | 显示全部楼层 |阅读模式

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

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

x
答案完全没看懂:
def f(x):
         result= ''
         if x:
                 result=f(x//2)
                 return result +str(x%2)
         else:
                 return result

         

当x==0的时候执行return result,然后执行return f(1//2)+str(1%2)再然后呢???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-2 14:01:28 | 显示全部楼层
等价于用循环实现:
    while dec:#这个循环用来找出每一位数0或1
        quo = dec % 2
        dec = dec // 2
        temp.append(quo)
    while temp:#逆序输出即得到结果
        result += str(temp.pop())

递归方法的要点在于理解一点:
当执行到递归时,其后续代码将暂停执行,等到返回时接着执行后续代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-2 14:05:17 | 显示全部楼层
BngThea 发表于 2018-4-2 14:01
等价于用循环实现:
    while dec:#这个循环用来找出每一位数0或1
        quo = dec % 2

return f(1//2)+str(1%2)再然后呢???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 14:49:50 | 显示全部楼层
文酱ww 发表于 2018-4-2 14:05
return f(1//2)+str(1%2)再然后呢???

不是return的这个
先执行递归,最后返回的时候才和后面的str(x%2)相加
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-2 15:15:41 | 显示全部楼层
BngThea 发表于 2018-4-2 14:49
不是return的这个
先执行递归,最后返回的时候才和后面的str(x%2)相加

我的意思就是问递归到0了然后在怎么return相加出来结果
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 15:23:14 | 显示全部楼层
文酱ww 发表于 2018-4-2 15:15
我的意思就是问递归到0了然后在怎么return相加出来结果

就是一步一步返回,不断执行result+=str(x%2)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-2 16:00:57 | 显示全部楼层
BngThea 发表于 2018-4-2 15:23
就是一步一步返回,不断执行result+=str(x%2)

我大概知道是这么算的,就是有几个细节我不明白
1。当x==1的时候,执行result==f(1//2)然后f(1//2)会执行else语句对吧,也就是执行return result。那么问题来了,前面还定义了一个result='',if 里面也定义了result,而且此时是在执行else语句,怎么会进入if里的return啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 16:08:27 | 显示全部楼层
文酱ww 发表于 2018-4-2 16:00
我大概知道是这么算的,就是有几个细节我不明白
1。当x==1的时候,执行result==f(1//2)然后f( ...

你还是绕进去了
你执行x为0的时候先return的result就是空字符串
然后返回到x为1的情况,result+=str(1%2)也就 '1'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 16:12:02 | 显示全部楼层
递归是这样的:
python.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-2 16:28:42 | 显示全部楼层
BngThea 发表于 2018-4-2 16:08
你还是绕进去了
你执行x为0的时候先return的result就是空字符串
然后返回到x为1的情况,result+=str(1% ...

也就是说result=f(x//2)在递归之后的return没有用是吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 16:29:55 | 显示全部楼层
文酱ww 发表于 2018-4-2 16:28
也就是说result=f(x//2)在递归之后的return没有用是吗

递归返回的时候f(x//2)这个已经结束了,接着往下执行
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-2 18:05:37 | 显示全部楼层
BngThea 发表于 2018-4-2 16:29
递归返回的时候f(x//2)这个已经结束了,接着往下执行

那为什么把result=f(x//2)改成z=f(x//2)只会有一个0啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 20:50:41 From FishC Mobile | 显示全部楼层
文酱ww 发表于 2018-4-2 18:05
那为什么把result=f(x//2)改成z=f(x//2)只会有一个0啊

修改的result没保存当然不行
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-3 18:55:20 | 显示全部楼层
BngThea 发表于 2018-4-2 20:50
修改的result没保存当然不行

什么意思?能说的具体一点吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-3 19:00:52 | 显示全部楼层
还有没有人来解答一下啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-3 19:04:23 | 显示全部楼层
文酱ww 发表于 2018-4-3 19:00
还有没有人来解答一下啊

大神们都说的很详细了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-3 20:40:53 | 显示全部楼层
a是十进制数
bin(a)
这样不就好了吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-4 20:17:53 | 显示全部楼层
塔利班 发表于 2018-4-3 19:04
大神们都说的很详细了

修改rensult=f(x//2)为啥不行?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-4 20:21:38 | 显示全部楼层
文酱ww 发表于 2018-4-4 20:17
修改rensult=f(x//2)为啥不行?

你要修改成什么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-4 20:52:10 | 显示全部楼层
草,我懂了。网上搜了一万年,自己有思索了一万年,终于明白了。以后还有不懂的小伙伴来这里@我哦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-27 17:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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