数据结构 | 栈-Python实现代码加可视化

1.栈的定义

堆栈(英语:stack)又称为栈或堆叠,是计算机科学中的一种抽象资料类型,只允许在有序的线性资料集合的一端(称为堆栈顶端,英语:top)进行加入数据(英语:push)和移除数据(英语:pop)的运算。因而按照后进先出(LIFO, Last In First Out)的原理运作,堆栈常用一维数组链表来实现。常与另一种有序的线性资料集合队列相提并论。

 也可以表示为:

2.栈的操作

  • Stack() 创建一个空的新栈
  • push(item)将一个新项添加到栈的顶部
  • pop() 从栈中删除顶部项
  • peek() 从栈返回顶部项,但不会删除它
  • is_Empty() 测试栈是否为空
  • size() 返回栈中的 item 数量

3.栈的Pytorch实现

class Stack(object):
    def __init__(self):  # 初始化栈为空列表
        self.items = []
    def is_empty(self):  # 判断栈是否为空,返回布尔值
        return self.items == []
    def peek(self):  # 返回栈顶元素
        return self.items[len(self.items) - 1]
    def size(self):  # 返回栈的大小
        return len(self.items)
    def push(self, item):  # 把新的元素堆进栈里面(入栈)
        self.items.append(item)
    def pop(self, item):  # 把栈顶元素丢出去(出栈)
        return self.items.pop()
if __name__ == '__main__':

    stack_=Stack()
    #stack_.push("香蕉","苹果","橘子")出错,一次只能push一个元素
    stack_.push('香蕉')#第一个输入的元素,就是最底下的元素
    stack_.push('苹果')
    stack_.push('橘子')#栈顶的元素
    print(stack_.size())#查看栈大小
    print(stack_.peek())#打印栈顶元素
    print(stack_.pop('苹果'))#删除顶部元素,就算定义删除中间的,也默认删除与顶部元素
    print(stack_.peek())#所以上面删掉了香蕉,现在上面的是苹果
    print(stack_.is_empty())  # 判断栈是不是空了?

结果:

4.实现可视化

 5.栈的应用

5.1.括号匹配(LeetCode题)

分析:如果我们把一个python列表看作一个栈,且列表末尾为栈顶。那么我们可以使用list.append来为实现push操作(为栈顶添加元素)。使用内置的pop函数来弹出栈顶元素。每遇到一个左括号就将其压入栈,每遇到一个右括号就和栈顶元素匹配,如果匹配成功则栈顶元素弹出。判断结果为:当循环完成时,栈为空,则返回True,否则返回False。

5.2.表达式转换

5.3.10进制转2进制

参考文献:

【1】https://en.wikipedia.org/wiki/Stack_(abstract_data_type)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏天|여름이다

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值