鱼C论坛

 找回密码
 立即注册
查看: 2664|回复: 3

[已解决]用递归编写一个 power() , power(x, y) 为计算并返回 x 的 y 次幂的值。

[复制链接]
发表于 2022-10-23 00:03:44 | 显示全部楼层 |阅读模式

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

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

x
def power(x, y):
    if y:
        return x * power(x, y-1)  ###这一步是怎么运算的啊
    else:
        return 1
   
print(power(2, 3))
最佳答案
2022-10-23 17:18:06
本帖最后由 dragov 于 2022-10-23 17:22 编辑

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-10-23 01:37:24 | 显示全部楼层
意思就是想得到x的y次方,可以用x乘以x的y-1次方,x的y-1次方怎么来呢,用x乘以x的y-2次方,以此类推,直到y-n为0的时候,x的0次幂是1,那反过来就知道了x乘以x的0次方为x,递归的思路非常考验正逆思维。但其实数学公式列好了,编程也简单。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2022-10-23 11:39:06 | 显示全部楼层
power(2 , 3) = 2 * power(2 , 2) = 2 * 2 * power(2 , 1) = 2 * 2 * 2 * power(2 , 0) = 2 * 2 * 2 * 1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2022-10-23 17:18:06 | 显示全部楼层    本楼为最佳答案   
本帖最后由 dragov 于 2022-10-23 17:22 编辑

递归.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-25 23:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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