函数在循环中递归调用自身:为什么代码无法运行并如何修复?

函数在循环中递归调用自身:为什么代码无法运行并如何修复?

函数在循环中的递归调用

原问题:一个求最大公约数的 python 程序,其函数在循环体中调用自身却无法运行:

a=666
b=1414
def gcd(x,y):
    x,y=y,x%y
    while(x%y>0):
        gcd(x,y)
    else:
        return y
print(gcd(666,1414))

修复:要使函数在循环中递归调用自身,必须在递归调用的位置返回结果。在给定代码中,缺失了递归函数中用于返回结果的 return 语句:

def gcd(x, y):
    x, y = y, x % y
    while x % y > 0:
        return gcd(x, y)  # <- 添加 return 语句
    else:
        return y

修改后,程序就能正确运行,输出最大公约数。

以上就是函数在循环中递归调用自身:为什么代码无法运行并如何修复?的详细内容,更多请关注其它相关文章!