递归

 

1.递归:在函数内调用自己
2.递归最大的层数限制:997

     证明递归的最大层数是997


View Cod

3.最大层数是python默认的可以修改
今天学到了一个sys,修改递归最大深度 global

View Code

但是不建议修改
4.递归解决的问题
通过参数,来控制每一次调用缩小计算的规模
5.适合场景
数据的规模在减小但解决问题的思路并没有变
6.结束递归的标志:return


例题: 

  用二分法找66

l=[2,3,4,5,6,8,10,18,22,56,66,88,99,101,122]
def find(l,aim):#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))
View Code

找到指定数的索引

l=[10,15,18,21,31,45,56,68,78,79,88,99]
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]:
        print("bingo")
        return mid

index = func(l,68)
print(index)
View Code

递归函数与三级菜单

menu = {
    '北京': {
        '海淀': {
            '五道口': {
                'soho': {},
                '网易': {},
                'google': {}
            },
            '中关村': {
                '爱奇艺': {},
                '汽车之家': {},
                'youku': {},
            },
            '上地': {
                '百度': {},
            },
        },
        '昌平': {
            '沙河': {
                '老男孩': {},
                '北航': {},
            },
            '天通苑': {},
            '回龙观': {},
        },
        '朝阳': {},
        '东城': {},
    },
    '上海': {
        '闵行': {
            "人民广场": {
                '炸鸡店': {}
            }
        },
        '闸北': {
            '火车战': {
                '携程': {}
            }
        },
        '浦东': {},
    },
    '山东': {},
}
View Code
 def threeLM(dic):
 2     while True:
 3         for k in dic:print(k)
 4         key = input('input>>').strip()
 5         if key == 'b' or key == 'q':return key
 6         elif key in dic.keys() and dic[key]:
 7             ret = threeLM(dic[key])
 8             if ret == 'q': return 'q'
 9         elif (not dic.get(key)) or (not dic[key]) :
10             continue
11 
12 threeLM(menu)
View
posted @ 2017-07-31 19:28  兰博~~  阅读(96)  评论(0编辑  收藏  举报