Python旅途——函数的递归和栈的使用

Posted guoruijie

tags:

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

Python——函数之递归、栈的使用

今天主要和大家分享函数的递归,同时引入一个新的概念——栈

1.递归

1.定义

函数的递归指的就是函数自己调用自己,什么是函数自己调用自己呢?我们来看一个栗子:

这里给大家一个数学中的一个数列:斐波那契数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368,它指的是前两项的和等于第三项,那么我们对于这样的需求如何用Python代码实现呢?这个时候就用到了函数的递归

def func(arg1,arg2):
    if arg1 == 0:
        print(arg1,arg2)
    # 拿到第三个值
    arg3 = arg1 + arg2 
    print arg3
    #将第二个值和第三个值作为参数继续传入函数中
    func(arg2,arg3)    
# 将斐波那契数列的前两项0,1传入函数  
func(0,1)                    

通过上面的这个例子,是不是对于递归有了一定的理解呢,但是递归本身是属于自己本身调用自己,这种方式是一种效率低,且消耗内存的一种方式

2.用递归实现三级菜单

三级菜单我们平时都是很常见的,像是在淘宝里买东西的时候,需要我们填写地址,这些操作我们仔细想想都是三级菜单,而且我们也可以通过递归来操作

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


def menu_func(menu):
    while True:
        # 循环打印menu,得到对应的键:北京、上海、广州
        for key in menu:                              
            print(key)
        inp = input('请输入要查询的地址(q退出,b返回上一级):').strip()
        if inp.upper() == 'Q': return 'q'
        if inp.upper() == 'B': return 'b'
         # 判断能否拿到对应正确的值
        elif menu.get(inp):      
            # 使用递归将用户输入的值再次进行循环打印显示                    
            flag = menu_func(menu[inp])    
            # 一层一层的return进行退出
            if flag == 'q': return 'q'                  
menu_func(menu)

2.栈lifo

这里在给大家介绍一个新的概念(数据结构)——栈 lifo(last in first out即后进先出)。

栈的特点就是后进先出,顾名思义,就是最后进来的数据要最先出去。那么上面的我们用递归实现的三级菜单,使用栈应该怎么实现呢?

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

 # 先将整个大的字典放在一个列表中
lst = [menu]    
#当列表不为空的时候,我们开始循环               
while lst:  
    #取列表的最后一项,即当前的大字典                    
    for key in lst[-1]: 
        # 北京                
        print(key)
    inp = input('>>>')
    # 输入q直接退出循环              
    if inp.upper() == 'Q':break 
    #返回上一级的时候,对列表进行pop,这样会默认删除掉列表最后的那个元素,对于再次循环列表时,拿到的最后一个元素就是上一层的菜单         
    elif inp.upper() == 'B':lst.pop() 
    # 从字典中取出你输入的地址,又对应拿到下一层的菜单                                                                                                 
    elif lst[-1].get(inp): 
        # 将对应的下一级菜单添加到列表中的最后一个位置上,反复循环。          
        lst.append(lst[-1][inp])         

以上就是函数的递归以及栈的相关分享。

以上是关于Python旅途——函数的递归和栈的使用的主要内容,如果未能解决你的问题,请参考以下文章

用递归函数和栈操作逆序栈

用递归函数和栈操作逆序栈

嵌套递归和栈的关系

如何仅用递归函数和栈操作逆序一个栈

堆和栈的区别:

堆和栈的区别