python 递归返回None

本文探讨了在Python中使用递归函数时,如何正确处理return语句以避免返回None的问题。通过辗转相除法求最大公约数的例子,说明了在递归过程中必须执行return语句的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

调用栈问题

需要确保每次递归调用都会执行return语句

否则,会默认返回空值

例子

def Euclidean_Algorithm(a, b):
    '''
    辗转相除法求最大公约数
    :param a:
    :param b: 
    :return: 最大公约数
    '''
    a, b = b % a, a
    # print(a, b)
    # 基线条件,整除
    if not a:
        return b
    # 递归条件
    else:
        # Euclidean_Algorithm(a, b)  # 错误,返回值为None. 因为递归过程没有执行return语句,返回空值
        return Euclidean_Algorithm(a, b)  # 正确

参考:

Python 递归函数返回值为None的解决办法 https://blog.youkuaiyun.com/ha_hha/article/details/79393041

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值