鱼C论坛

 找回密码
 立即注册
查看: 1121|回复: 5

[已解决]递归怎么理解2个参数计算?

[复制链接]
发表于 2020-6-18 15:50:22 | 显示全部楼层 |阅读模式

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

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

x
  1. def power(x,y):

  2.     if y:
  3.         return x * power(x,y-1)
  4.     else:
  5.         return 1
复制代码



#求 x 的 y 次幂,if y是设置停止条件对吗?因为不能有0次幂? 当y为True的时候 x * power(x,y-1)怎么理解,比如 x = 2  y = 3的话?计算过程是什么样子的
最佳答案
2020-6-18 15:59:27
求 x 的 y 次幂,if y是设置停止条件对吗?


不是的~ else 才是停止,而if 是设置递归条件,满足条件就递归,不满足就不递归

因为不能有0次幂?


任何数的0次幂都是 0  包括 0

当y为True的时候 x * power(x,y-1)怎么理解,比如 x = 2  y = 3的话?计算过程是什么样子的


看注释:

  1. def power(x,y):

  2.     if y: # 初始值 x = 2 ,y = 3
  3.         # 第一次递归x = 2 , y = 2 满足条件继续进入 if
  4.         # 第二次递归x = 2 ,  y = 1 满足条件进入 if
  5.         # 第三次递归x = 2 , y = 0 不满足条件 进入else

  6.         return x * power(x,y-1)  # 2*power(2,2)第一次进入递归
  7.     # 第一次递归返回: 2 * power(2,1) 进入第二次递归
  8.     # 第二次递归返回: 2 * power(2,0) 进入第三次递归

  9.     else:
  10.         return 1  # 返回 1
  11.     # 递归返回顺序 power(2,0) -> power(2,1) ->power(2,2) -> power(2,3)
  12.     #  返回值:        1     -> 2*1      ->  2*2*1 ->     2*2*2*1
  13. print(power(2,3))

  14. # 最后结果为 8
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-6-18 15:54:44 | 显示全部楼层
本帖最后由 heidern0612 于 2020-6-18 15:56 编辑

if y表示如果y不为零的话,就返回x * power(x,y-1).

否则的话(y为0)返回1.任何数的0次方都是1.

power只是个计算次幂的函数,知道这么算就行了。

x为2,y为3的话,就是2的3次方,返回 2*Pow(2,2),返回的结果就是2的3次方。

因为x本身也代表了一次y的一个次幂数,所以y减去了1。

跟你直接返回pow(2,3)是一样的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-18 15:59:27 | 显示全部楼层    本楼为最佳答案   
求 x 的 y 次幂,if y是设置停止条件对吗?


不是的~ else 才是停止,而if 是设置递归条件,满足条件就递归,不满足就不递归

因为不能有0次幂?


任何数的0次幂都是 0  包括 0

当y为True的时候 x * power(x,y-1)怎么理解,比如 x = 2  y = 3的话?计算过程是什么样子的


看注释:

  1. def power(x,y):

  2.     if y: # 初始值 x = 2 ,y = 3
  3.         # 第一次递归x = 2 , y = 2 满足条件继续进入 if
  4.         # 第二次递归x = 2 ,  y = 1 满足条件进入 if
  5.         # 第三次递归x = 2 , y = 0 不满足条件 进入else

  6.         return x * power(x,y-1)  # 2*power(2,2)第一次进入递归
  7.     # 第一次递归返回: 2 * power(2,1) 进入第二次递归
  8.     # 第二次递归返回: 2 * power(2,0) 进入第三次递归

  9.     else:
  10.         return 1  # 返回 1
  11.     # 递归返回顺序 power(2,0) -> power(2,1) ->power(2,2) -> power(2,3)
  12.     #  返回值:        1     -> 2*1      ->  2*2*1 ->     2*2*2*1
  13. print(power(2,3))

  14. # 最后结果为 8
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-18 16:02:40 | 显示全部楼层
本帖最后由 jackz007 于 2020-6-18 16:07 编辑
  1. power(2 , 3)
  2. = 2 * power(2 , 2)             # power(2 , 3) = 2 * power(2 , 2)
  3. = 2 * 2 * power(2 , 1)         # power(2 , 2) = 2 * power(2 , 1)
  4. = 2 * 2 * 2 * power(2 , 0)     # power(2 , 1) = 2 * power(2 , 0)
  5. = 2 * 2 * 2 * 1                # power(2 , 0) = 1
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-18 16:07:25 | 显示全部楼层
Twilight6 发表于 2020-6-18 15:59
不是的~ else 才是停止,而if 是设置递归条件,满足条件就递归,不满足就不递归

等于说我虽然求的2的3次方,但是用递归的话power函数对y进行了一共4次计算(包含了终止条件1),比如说 2的平方就是 2 * power(2,2-1)这样去递归计算,最后其实代码的计算过程就是2*2*1  对这样简单一些的东西来说递归反而计算复杂了,对吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-18 16:09:09 | 显示全部楼层
Aber 发表于 2020-6-18 16:07
等于说我虽然求的2的3次方,但是用递归的话power函数对y进行了一共4次计算(包含了终止条件1),比如说 2 ...


0的0次方是悬而未决的,在某些领域定义为1、某些领域不定义(无意义)。

刚刚百度到,我纠正下  任何除 0 外的 0 次方都为 1
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-22 02:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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