| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
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
 
  复制代码 
 
 
 |   
 
 
 
 |