一、递归函数

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

 

递归的最大深度

执行次数是998/997 解释器会主动强制停止,报错.保护内存

 

def foo(n):
    print(n)
    n += 1
    foo(n)
foo(1)

  

修改递归最大深度

import sys
sys.setrecursionlimit(100000)
def foo(n):
    print(n)
    n += 1
    foo(n)
foo(1)

  

递归函数: 优点:复杂的逻辑用递归非常简单.

                缺点:递归次数多了,占用内存,费时间

 

实例 1 ----- 问年龄


def age(n):
    if n == 1:
        return 40
    else:
        return age(n-1)+2
print(age(4))

  实例 2----- 用递归函数求阶乘

def fn(n): 
    if n == 1:return 1
    return fn(n-1) * n
print(fn(5))

  

  实例 3----- 斐波那契数列


普通版
def fib(n):
    if n == 1 or n == 2:return 1
    else:
        return fib(n-1)+fib(n-2)
print(fib(100))


升级版
def fib(n,a=0,b=1):    #算法
    if n==1 or n == 2:
        return a+b
    else:
        return fib(n-1,b,a+b)

  实例 4 ------- 用递归函数实现三级菜单

menu = {
    '北京': {
        '海淀': {
            '五道口': {
                'soho': {},
                '网易': {},
                'google': {}
            },
            '中关村': {
                '爱奇艺': {},
                '汽车之家': {},
                'youku': {},
            },
            '上地': {
                '百度': {},
            },
        },
        '昌平': {
            '沙河': {
                '老男孩': {},
                '北航': {},
            },
            '天通苑': {},
            '回龙观': {},
        },
        '朝阳': {},
        '东城': {},
    },
    '上海': {
        '闵行': {
            "人民广场": {
                '炸鸡店': {}
            }
        },
        '闸北': {
            '火车战': {
                '携程': {}
            }
        },
        '浦东': {},
    },
    '山东': {},
}


def menu3(menu):
    while True:
        for key in menu:       # 北京 上海 山东
            print(key)
        choice = input('>>>')  # 用户输入选择 北京
        if choice in menu and menu[choice]:
            ret = menu3(menu[choice])
            if ret == 'q': return ret
        elif choice == 'b' or choice == 'q':
            return choice
menu3(menu)
三级菜单

相关文章: