鱼C论坛

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

[已解决]求助数学逻辑

[复制链接]
发表于 2017-9-30 13:59:32 | 显示全部楼层 |阅读模式

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

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

x
def power(x,y):
    if y:
        return x * power(x, y-1)
    else:
        return 1

number1 = int(input('请输入x:'))
number2 = int(input('请输入y:'))
print("%d 的 %d次幂等于: %d" % (number1, number2, power(number1,number2)) )

提问:
1、return x * power(x, y-1) 为什么代表x的y次幂?请教帮助解释一下。

2、在什么情况下会出现
    else:
        return 1

谢谢您的回答与帮助。
最佳答案
2017-9-30 14:29:17
递归2大条件:
1,在合适的时候退出递归。
      如: else:
                        return 1
2,函数调用函数自身。
     如:power(x, y-1)

2017-09-30_142645.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-9-30 14:29:17 | 显示全部楼层    本楼为最佳答案   
递归2大条件:
1,在合适的时候退出递归。
      如: else:
                        return 1
2,函数调用函数自身。
     如:power(x, y-1)

2017-09-30_142645.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-30 16:51:21 | 显示全部楼层
1、return x * power(x, y-1) 为什么代表x的y次幂?
这是递归调用,每次调用自身时y的值都会减少1,并最终为0

2、在什么情况下会出现
    else:
        return 1
当不断递归后y的值变为0后if判断为False,执行else
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-10-2 21:29:45 | 显示全部楼层
ba21 发表于 2017-9-30 14:29
递归2大条件:
1,在合适的时候退出递归。
      如: else:

感谢您辛苦给我画图,我看懂了。谢谢!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-2 20:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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