基础知识
栈也是一种特殊的线性表,他只能对栈顶进行添加和删除元素。栈有入栈和出栈两种操作,他就好像我们把书一本本的摞起来,最先放的书肯定是摞在下边,最后放的书肯定是摞在了最上面,摞的时候不允许从中间放进去,拿书的时候也是先从最上面开始拿,不允许从下边或中间抽出来。
栈的原理图
栈的实现可以使用数组也可以使用链表,我们这里分析的主要是使用数组的形式。

代码实现
栈的实现其实非常简单,常见的就两种操作,一种是压栈一种是出栈,我们来看下代码

这里为了方便,栈的空间大小在初始化的时候就就已经固定了,并且栈满的时候没有扩容,栈是一个非常有用的数据结构,尤其在算法中用到的还是比较多的。栈是一种先进后出的数据结构,它和队列正好相反,队列是一种先进先出的数据结构。
例子
我们来看个非常简单的例子,验证括号的有效性,括号只包含"(",")","[","]","{","}"这6个字符,比如(),{()},[](){}都是有效的,而{],{(]}都是无效的。
我们来分析一下这道题,当我们遍历到括号的左半边的时候,我们把括号的右半边压栈,当我们遍历到括号右半边的时候,我们就把栈顶的元素弹出,然后在和我们遍历的符号比较看是否一样,我们以字符串"{([]())}"为例来画图分析一下,


搞懂了上面的图,写出代码就容易多了,我们来看下代码怎么实现

想了解更多数据结构以及算法题,可以关注微信公众号“数据结构和算法”
本文介绍了栈这种特殊线性表,它只能对栈顶进行元素添加和删除,有入栈和出栈操作,可使用数组或链表实现。以数组形式为例分析了栈的实现,还给出验证括号有效性的例子,通过遍历括号压栈和出栈操作来判断其有效性。
1115

被折叠的 条评论
为什么被折叠?



