python-递归函数

Posted dwenwen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python-递归函数相关的知识,希望对你有一定的参考价值。

默认的递归最大限度1000
不要修改默认的递归最大限度
往往递归都是和循环挂在一起的
人理解循环,神理解递归
算法
认识递归
递归函数怎么读?
例题

算法:一种计算的方法
典型问题:冒泡排序,快速排序,堆排序
二分查找法:查找下面例题中的58
二分查找
def find_2(l,aim,start=0,end=None):
    if end == None:end = len(l) -1
    if end >= start:
        mid = (end - start) // 2 + start
        if l[mid] > aim:
            ret = find_2(l,aim,start,mid-1)
            return ret
        elif l[mid] < aim :
            ret = find_2(l,aim,mid+1,end)
            return ret
        else:return aim,mid
    else :
        print(\'查找不到内容\')

find_2(l,58)

阶乘的计算
什么叫阶乘:7*6*5*4*3*2*1
阶乘的计算
斐波那契数列
斐波

 

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


def menu_3(menu):
    while True:
        for key in menu:
            print(key)
        choice = input(\'choice:\')
        if choice == \'q\' or choice == \'b\':
            return choice
        if choice in menu and menu[choice]:
            borq = menu_3(menu[choice])
            if borq == \'q\': return \'q\'


menu_3(menu)


 

 

 
 

 

以上是关于python-递归函数的主要内容,如果未能解决你的问题,请参考以下文章

python递归函数

如何在自定义 PyYAML 构造函数中处理递归?

Python的递归函数

nodejs常用代码片段

python开发 随笔补充之递归函数与实例

Python入门教程第25篇 递归函数