小甲鱼Python第二十二讲(递归)

求阶乘(递归的办法)
def digui(n):
    if n==1:
        return 1
    else:
        return  n * digui(n-1)

number =int(input("输入一个正整数:"))
print(digui(number))

测试题
在这里插入图片描述

0、递归表现调用本身的一个行为
1、(1)调用自身函数 (2)设置正确的返回条件
2、像汉诺塔、快速排序
3、用递归算法时,一定要注意设置递归的出口,否则将会陷入无限递归的过程。

在这里插入图片描述

动动手
在这里插入图片描述

0def power(x,y):
    if y == 1:
        return x
    else:    
        return x * power(x,y-1)
print('------------------幂运算-----------------------')
Bnum = int(input('请输入一个底数:'))
Enum = int(input('请输入指数:'))
result = power(Bnum,Enum)
print('%d的%d次方等于%d.'%(Bnum,Enum,result))
def gcd(m,n):
    if n == 0:
       return m
    else:
        return gcd(n,m%n)

a = int(input('请输入第一个正整数:'))

b = int(input('请输入第二个正整数:'))

result = gcd(a,b)

print('%d与%d的最大公约数是:%d'%(a,b,result))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值