什么是递归函数:在一个函数内再调用这个函数本身,这样的函数就叫递归函数。
山里有座庙,庙里有个老和尚,老和尚在讲故事讲什么呢?山里有座庙,庙里有个老和尚,老和尚在讲故事讲什么呢?山里有座庙,庙里有个老和尚,老和尚在讲故事讲什么呢?山里有座庙,庙里有个老和尚,老和尚在讲故事讲什么呢?山里有座庙,庙里有个老和尚,老和尚在讲故事讲什么呢?......................
一直这样循环下去。怎样用递归函数来写这个故事呢?
#在函数中调用这个函数本身,称这个函数为递归函数View Code
def story():
s = "山里有座庙,庙里有个老和尚在讲故事,在讲什么呢?"
print(s)
story()
story()
递归函数不是无限的循环下去的,最大循环层数是997层。可以根据需求修改,但是不建议修改,因为一直调用函数,名称空间会占用很多内存。
n = 0
import sys
sys.setrecursionlimit(100000)#setrecursionlimit括号中的内容可以修改
def f():
global n#引用全局变量
n+= 1
print(n)
f()
f()
#视个人电脑性能,得到的数字不一样
递归函数 二分查找算法
二分查找算法,主要针堆比较大的有序列表数据,取值
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]
从里面取出66
以列表中间比大小。
l = [2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,65,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)
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
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]:
return mid
index = func(l,68)
print(index)
递归函数与三级菜单:
menu = {menu
'北京': {
'海淀': {
'五道口': {
'soho': {},
'网易': {},
'google': {}
},
'中关村': {
'爱奇艺': {},
'汽车之家': {},
'youku': {},
},
'上地': {
'百度': {},
},
},
'昌平': {
'沙河': {
'老男孩': {},
'北航': {},
},
'天通苑': {},
'回龙观': {},
},
'朝阳': {},
'东城': {},
},
'上海': {
'闵行': {
"人民广场": {
'炸鸡店': {}
}
},
'闸北': {
'火车战': {
'携程': {}
}
},
'浦东': {},
},
'山东': {},
}
menu
用循环的笨办法写一遍
while True:View Code
for key in menu:
print(key)
num_1 = input(">>>>:")
if num_1 in menu.keys():
while True:
for i in menu[num_1]:
print(i)
num_2 = input(">>>>>:")
if num_2 in menu[num_1]:
for j in menu[num_1][num_2]:
print(j)
num_3 = input(">>>>:")
if num_3 in menu[num_1][num_2]:
for k in menu[num_1][num_2][num_3]:
print(k)
elif num_3 == "back":
break
else:
continue
elif num_2 == "back":
break
else:
continue
elif num_1 == "back":
break
else:
continue
再用递归写一遍这个菜单
def threeLM(dic):
while True:
for k in dic : print(k)
key = input(">>>:").strip()
if key == "b" or key == "q":return key#输入b或者q结束程序,return终止程序
elif key in dic.keys() and dic[key]:
ret = threeLM(dic[key])
if ret == "q":return "q"
elif (not dic.get(key)) or (not dic[key]):
continue
threeLM(menu)