鱼C论坛

 找回密码
 立即注册
查看: 3149|回复: 7

[已解决]递归函数2

[复制链接]
发表于 2022-9-28 09:43:41 | 显示全部楼层 |阅读模式

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

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

x
如何使用python 求解以上递归函数的返回值!
最佳答案
2022-9-28 10:28:16
def f(x):
    if not x % 2:
        return f(x // 2) + 1
    elif x % 2 and x > 3:
        return f(x + 3) - 1
    else:
        return (x + 1) / 2

print(f(20))

递归函数求解

递归函数求解
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-28 10:10:28 | 显示全部楼层
本帖最后由 jackz007 于 2022-9-28 10:26 编辑
def foo(x):
    r = (x + 1) // 2    
    if not x % 2:
        r = foo(x // 2) + 1
    elif x % 2 and x > 3:
        r = foo(x + 3) - 1
    return r

print(foo(20))

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

使用道具 举报

发表于 2022-9-28 10:28:16 | 显示全部楼层    本楼为最佳答案   
def f(x):
    if not x % 2:
        return f(x // 2) + 1
    elif x % 2 and x > 3:
        return f(x + 3) - 1
    else:
        return (x + 1) / 2

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

使用道具 举报

 楼主| 发表于 2022-9-28 10:47:20 | 显示全部楼层
def F(x):
    if x%2 == 0:
        return F(x/2) + 1
    elif x%2 == 1 and x > 3:
        return F(x + 3) - 1
    else:
        return (x + 1) / 2

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

使用道具 举报

 楼主| 发表于 2022-9-28 10:47:55 | 显示全部楼层
以上是我自己敲的代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-28 13:07:18 From FishC Mobile | 显示全部楼层
f = lambda x: f(x >> 1) + 1 if not x%2 else f(x + 3) - 1 if x%2 and x > 3 else (x + 1) >> 1
print(f(20))
5
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-28 18:47:55 | 显示全部楼层

好精炼的语句,麻烦可以解释下吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-28 19:17:30 | 显示全部楼层
本帖最后由 傻眼貓咪 于 2022-9-28 19:18 编辑
nbwubo 发表于 2022-9-28 18:47
好精炼的语句,麻烦可以解释下吗?


(一)lambda 是匿名函数,f = lambda xxxxx 这里 f 就是函数,匿名函数好处是代码简约,通常一行代码,当然还有其它真正用法。坏处是阅读困难,复杂函数无法用 lambda 方式呈现(但用lambda调用其它函数就另当别论)
(二)x >> 1 如同 x // 2(只是做法不同,一个是位运算,一个是普通除法。位运算好处是结果始终是整数)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-15 05:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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