数据结构与算法(Python)——常见数据结构Part2(栈和递归)

本文介绍了栈数据结构及其在Python中的实现,包括括号匹配问题和迷宫问题的解决方法。栈是后进先出(LIFO)结构,可以用list作为栈来使用。此外,文章探讨了栈在递归调用中的作用,并通过实例展示了如何利用递归解决阶乘计算。
摘要由CSDN通过智能技术生成

写在前面

在上一节part1我们熟悉数组和链表,本节继续对其他常见数据结构进行总结。我们的目的是快速了解他们,对于它们涉及到的复杂的数据结构和算法,在这里并不全部展开,留在后期详述。

1. 栈

栈(stack)也是一种线性结构,与数组不同的是,栈限定了只能在线性表的一端,例如尾部进入插入或者删除操作(只允许头部操作类似)。

栈类似于把车开入了一个死胡同,只剩下一端,只能从这个入口进入或者出去,这个进入称之为入栈操作(push),退出则称之为出栈操作(pop)。最后在这个死胡同里,车子只能从最后进入的那位开始依次往后倒车开出去,这就是连续出栈操作,直到栈为空。在出栈过程中,最先进入的最后出去,这称之为后进先出(Last In First Out,LIFO)

在数据结构中,栈中一般存储同类型元素,当然也允许存储不同类型元素,例如动态语言中实现的栈。栈的操作如下图所示(图片来自tutorial point):

stack

1.1 栈的实现

Python中没有显式提供栈结构,不过list结构可以当做栈来使用。
入栈和出栈操作实现为:

    stack = ['a']
    stack.append('b')   # 入栈操作
    stack.append('c')
    print(stack)   # ['a', 'b', 'c']
    content = stack.pop()  # 出栈操作
    print(content) # 'c'
    print(stack)   # ['a', 'b']

下面我们也对list进行一个封装,自己动手实现一个简单的栈。

class Stack(object):

    """
    栈
    """

    def __init__(self):
        self.data = []

    def __str__(self):
        output_str = "stack["
        for x in self.data:
            output_str += str(x)+","
        output_str += "]"
        return output_str

    def is_empty(self):
        return not self.data

    def push(self, element):
        self.data.append(element)

    def pop(self):
        return self.data.pop()

    def top(self):
        if self.data:
            return
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值