|  | 
 
 发表于 2020-6-18 15:59:27
|
显示全部楼层
   本楼为最佳答案 
| 求 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
 | 
 |