1.什么是递归:在一个函数里在调用这个函数自己 2.最大递归层数作了一个限制:997,可是也能够本身限制python
def foo(n):
print(n)
n+=1
foo(n)
foo(1)
复制代码
3.最大层数限制是python默认的,能够作修改,可是不建议你修改。(由于若是用997层递归都没有解决的问题要么是不适合使用递归来解决问题,要么就是你的代码太烂了)算法
import sys
sys.setrecursionlimit(10000000)#修改递归层数
n=0
def f():
global n
n+=1
print(n)
f()
f()
复制代码
咱们能够经过以上代码,导入sys模块的方式来修改递归的最大深度。 sys模块:全部和python相关的设置和方法 4.结束递归的标志:return 5.递归解决的问题就是经过参数,来控制每一次调用缩小计算的规模 6.使用场景:数据的规模在减小,可是解决问题的思路没有改变 7.不少排序算法会用到递归bash
1.下面咱们来猜一下小明的年龄函数
小明是新来的同窗,丽丽问他多少岁了。ui
他说:我不告诉你,可是我比滔滔大两岁。google
滔滔说:我也不告诉你,我比晓晓大两岁spa
晓晓说:我也不告诉你,我比小星大两岁code
小星也没有告诉他说:我比小华大两岁cdn
最后小华说,我告诉你,我今年18岁了blog
这个怎么办呢?固然,有人会说,这个很简单啊,知道小华的,就会知道小星的,知道小星的就会知道晓晓的,以此类推,就会知道小明的年龄啦。这个过程已经很是接近递归的思想了。
姓名 | 年龄 |
---|---|
小华 | 18+2 |
小星 | 20+2 |
晓晓 | 22+2 |
滔滔 | 24+2 |
小明 | 26+2 |
上面的图咱们能够用个序号来表示吧
age(5) = age(4)+2
age(4) = age(3) + 2
age(3) = age(2) + 2
age(2) = age(1) + 2
age(1) = 18
复制代码
那么代码该怎么写呢?
def age(n):
if n ** 1:
return 18
else:
return age(n - 1) + 2
ret=age(6)
print(ret)
复制代码
2.一个数,除2直到不能整除2
def cal(num):
if num % 2 ** 0: ## 先判断能不能整除
num = num // 2
return cal(num)
else:
return num
print(cal(8))
复制代码
3.若是一个数能够整除2,就整除,不能整除就*3+1
def func(num):
print(num)
if num**1:
return
if num%2**0:
num=num//2
else:
num=num*3+1
func(num)
func(5)
复制代码
menu = {
'北京': {
'海淀': {
'五道口': {
'soho': {},
'网易': {},
'google': {}
},
'中关村': {
'爱奇艺': {},
'汽车之家': {},
'youku': {},
},
'上地': {
'百度': {},
},
},
'昌平': {
'沙河': {
'老男孩': {},
'北航': {},
},
'天通苑': {},
'回龙观': {},
},
'朝阳': {},
'东城': {},
},
'上海': {
'闵行': {
"人民广场": {
'炸鸡店': {}
}
},
'闸北': {
'火车战': {
'携程': {}
}
},
'浦东': {},
},
'山东': {},
}
复制代码
代码实现:
def threeLM(menu):
while True:
for key in menu:#循环字典的key,打印出北京,上海,山东
print(key)
name=input('>>>:').strip()
if name**'back' or name**'quit':#若是输入back,就返回上一层。若是输入quit就退出
return name #返回的name的给了ret
if name in menu:
ret=threeLM(menu[name])
if ret**'quit':return 'quit'#若是返回的是quit,就直接return quit 了,就退出了
threeLM()
## print(threeLM(menu))#print打印了就返回出quit了,threeLM()没有打印就直接退出了
复制代码
从这个列表中找到55的位置l = 【2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,56,66,67,69,72,76,82,83,88】
按照上面的图就能够实现查找了。 简单的二分法
l = [2, 3, 5, 10, 15, 16, 18, 22, 26, 30, 32, 35, 41, 42, 43, 55, 56, 66, 67, 69, 72, 76, 82, 83, 88]
def find(l,aim):
mid=len(l)//2#取中间值,//长度取整(取出来的是索引)
if l[mid]>aim:#判断中间值和要找的那个值的大小关系
new_l=l[:mid]#顾头不顾尾
return find(new_l,aim)#递归算法中在每次函数调用的时候在前面加return
elif l[mid]<aim:
new_l=l[mid+1:]
return find(new_l,aim)
else:
return l[mid]
print(find(l,66))
复制代码
升级版二分法
l = [2, 3, 5, 10, 15, 16, 18, 22, 26, 30, 32, 35, 41, 42, 43, 55, 56, 66, 67, 69, 72, 76, 82, 83, 88]
def func(l, aim,start = 0,end = len(l)-1):
mid = (start+end)//2#求中间的数
if not l[start:end+1]:#若是你要找的数不在里面,就return'你查找的数字不在这个列表里面'
return '你查找的数字不在这个列表里面'
elif aim > l[mid]:
return func(l,aim,mid+1,end)
elif aim < l[mid]:
return func(l,aim,start,mid-1)
elif aim ** l[mid]:
print("bingo")
return mid
index = func(l,55)
print(index)
## print(func(l,41))
复制代码