|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- def power(x,y):
- if y:
- return x * power(x,y-1)
- else:
- return 1
复制代码
#求 x 的 y 次幂,if y是设置停止条件对吗?因为不能有0次幂? 当y为True的时候 x * power(x,y-1)怎么理解,比如 x = 2 y = 3的话?计算过程是什么样子的
求 x 的 y 次幂,if y是设置停止条件对吗?
不是的~ else 才是停止,而if 是设置递归条件,满足条件就递归,不满足就不递归
任何数的0次幂都是 0 包括 0
当y为True的时候 x * power(x,y-1)怎么理解,比如 x = 2 y = 3的话?计算过程是什么样子的
看注释:
- def power(x,y):
- if y: # 初始值 x = 2 ,y = 3
- # 第一次递归x = 2 , y = 2 满足条件继续进入 if
- # 第二次递归x = 2 , y = 1 满足条件进入 if
- # 第三次递归x = 2 , y = 0 不满足条件 进入else
- return x * power(x,y-1) # 2*power(2,2)第一次进入递归
- # 第一次递归返回: 2 * power(2,1) 进入第二次递归
- # 第二次递归返回: 2 * power(2,0) 进入第三次递归
- else:
- return 1 # 返回 1
- # 递归返回顺序 power(2,0) -> power(2,1) ->power(2,2) -> power(2,3)
- # 返回值: 1 -> 2*1 -> 2*2*1 -> 2*2*2*1
- print(power(2,3))
- # 最后结果为 8
复制代码
|
|