链栈是栈的一种实现方法,特指用链表实现栈存储结构。
链栈的实现思路和顺序栈类似,顺序栈是将顺序表(数组)的一端做栈底,另一端做栈顶;链栈也是如此,我们通常将链表的头部做栈顶,尾部做栈底,如图 1 所示:
图 1 链栈示意图
以链表的头部做栈顶,最大的好处是:可以避免在实现元素 "入栈" 和 "出栈" 时做大量遍历链表的耗时操作。有元素入栈时,只需要将其插入到链表的头部;有元素出栈时,只需要从链表的头部依次摘取结点。
因此,链栈实际上是一个采用头插法插入或删除数据的链表。
链栈元素入栈
例如,依次将 1、2、3、4 存储到栈中,每个元素的入栈过程如图 2 所示:
图 2 链栈元素依次入栈过程示意图
C语言实现代码为:
//链表中的节点结构
typedef struct lineStack {
int d