递归函数

递归的定义:在一个函数里再调用函数本身。

递归的最大深度:997

递归函数与三级菜单:

menu = {
    '北京': {
        '海淀': {
            '五道口': {
                'soho': {},
                '网易': {},
                'google': {}
            },
            '中关村': {
                '爱奇艺': {},
                '汽车之家': {},
                'youku': {},
            },
            '上地': {
                '百度': {},
            },
        },
        '昌平': {
            '沙河': {
                '老男孩': {},
                '北航': {},
            },
            '天通苑': {},
            '回龙观': {},
        },
        '朝阳': {},
        '东城': {},
    },
    '上海': {
        '闵行': {
            "人民广场": {
                '炸鸡店': {}
            }
        },
        '闸北': {
            '火车战': {
                '携程': {}
            }
        },
        '浦东': {},
    },
    '山东': {},
}
def threeLM(dic):
      while True:
          for k in dic:print(k)
          key = input('input>>').strip()
          if key == 'b' or key == 'q':return key
          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)

python之路——二分查找算法

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]:
        print("bingo")
        return mid

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

 

posted @ 2017-08-01 15:29  妙香沫颜  阅读(152)  评论(0编辑  收藏  举报