数据结构——栈

本文探讨了栈这种数据结构,介绍了如何用数组实现动态扩容的顺序栈,分析了其时间复杂度。同时阐述了栈在函数调用、表达式求值和括号匹配中的应用,通过实例展示了栈在解决实际问题中的重要作用。
摘要由CSDN通过智能技术生成

最近开始学习王争老师的《数据结构与算法之美》,通过总结再加上自己的思考的形式记录这门课程,文章主要作为学习历程的记录。

栈可以看作是一种“操作受限”的线性表,当某个数据只涉及在一端插入和删除数据,并满足后进先出,先进后出的特性,应首选“栈”这种数据结构。如下图:

用数组实现的栈,叫做顺序栈,用链表实现的栈,叫做链式栈。不管是顺序栈还是链式栈,存储数据只需要一个大小为n的数组。在入栈和出栈过程中,只需要一两个临时变量存储空间,因此空间复杂度为O(1)。但这不意味空间复杂度为O(n)。因为这n个空间是必须的,无法省掉。因此说空间复杂度的时间,除了原本的数据存储空间,算法运行还需要额外的存储空间。

支持动态扩容的顺序栈

在这里插入图片描述
动态过程如上,当数组空间不够时,我们就重新申请一块更大的内存,将原来的数组中的数据统统拷贝过去。

对于出栈操作来说,我们不会涉及内存的重新申请和数据搬移,所以出栈的时间复杂度仍是O(1).但当空间不够时,就需要重新申请内存和数据搬移,时间复杂度即为O(n)。因此最好情况时间复杂度是O(1),最坏情况时间复杂度是O(n)。平均情况下的时间复杂度可以用摊还分析法。如下图,因此可以得到入栈操作的均摊时间复杂度为O(1)。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值