什么是递归函数?
是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现象。在计算机编程里,递归指的是一个过程:函数不断引用自身,直到引用的对象已知。
使用递归解决问题,思路清晰,代码少。但是在主流高级语言中(如C语言、Pascal语言等)使用递归算法要耗用更多的栈空间,所以在堆栈尺寸受限制时(如嵌入式系统或者内核态编程),应避免采用。所有的递归算法都可以改写成与之等价的非递归算法。
递归就是在函数内部调用自己的函数被称之为递归。
例:
#调用自己
def func():
print('from func')
func()
func()
#间接调用自己
def foo():
print('from foo')
bar()
def bar():
print('from bar')
foo()
foo()
#递归的实现:
def age(n):
if n==1:
return 18
return age(n-1)+2
print(age(5))
递归的回溯与递推
1. 递推
像上边递归实现所拆解,递归每一次都是基于上一次进行下一次的执行,这叫递推。
2. 回溯
则是在遇到终止条件,则从最后往回返一级一级的把值返回来,这叫回溯。
例:
l =[1, 2, [3, [4, 5, 6, [7, 8, [9, 10, [11, 12, 13, [14, 15,[16,[17,18]],19]]]]]]]
def search(a):
for item in a:
if type(item) is list:
search(item)
else:
print(item)
search(a)
小练习
阶乘:
def fact(n):
if n==1:
return 1
return n*fact(n-1)
print(fact(100))
输出结果:
斐波那契数列:
def fib(n):
if n<2:
return n
else:
return fib(n-1)+fib(n-2)
print(fib(20))
输出结果:
汉诺塔:
def hanoti(n,x1,x2,x3):
if(n==1):
print('move:',x1,'---',x3)
return
hanoti(n-1,x1,x3,x2)
print('move:',x1,'---',x3)
hanoti(n-1,x2,x1,x3)
使用递归函数向控制台打印3,2,1
def print_num(num):
print(num)
#出口
if num==3:
return
num=num-1
print_num(num) #调用自己
print('----->')
查找数字:通过程序查找输入的number值。
def search(number,start,end):
if number ==start:
return start
else:
middle=(start+end)//2
if middle<=number:
return search(number,middle,end)
else:
return search(number,start,middle)