函数的递归
在一个函数体中调用函数本
定义一个函数,求3的阶乘(1*2*3)
def f(n):
if n==1:
return 1
else:
return n*f(n-1)
r=f(3)
print(r)
执行流程
1.实参3传递给n,函数f(3),
执行判断,3不等于1,所返回3f(3-1) 也就是3f(2)
2.f(2)执行判断
2不等于1,返回2f(2-1) 也就是2f(1)
3.f(1)执行判断
1等于1,返回 1
最终得到123
f(3)=3*f(2)
=3*2*f(1)
=3*2*1
函数的闭包
内部函数对外部函数的变量进行引用,内部函数就被认为是闭包.
当外部函数引用时还返回了内部函数
def f(a,b):
def g(x):
print(a*x+b)
return g
r=f(5,2) # 和下一步可以写作 f(5,2)(3)
r(3)
def f(a,b):
def g(x)
print(ax+b)
return g
f(5,2)(3) #a=5,b=2,x=3 因为在调用函数f时也返回了函数g,
调用函数f()时,返回了函数g(),函数f()中的数据(5,2)在函数g()中保存起来.