鱼C论坛

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

[已解决]递归函数2

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

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

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

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

  8. print(f(20))
复制代码

递归函数求解

递归函数求解
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

  8. print(foo(20))
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

  8. print(f(20))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

  8. print(int(F(20)))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-9-28 10:47:55 | 显示全部楼层
以上是我自己敲的代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-28 13:07:18 From FishC Mobile | 显示全部楼层
  1. 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
  2. print(f(20))
复制代码
  1. 5
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

好精炼的语句,麻烦可以解释下吗?
小甲鱼最新课程 -> https://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(只是做法不同,一个是位运算,一个是普通除法。位运算好处是结果始终是整数)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-26 18:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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