data:image/s3,"s3://crabby-images/8df7e/8df7e86fe30810f206dd560e69161863d0f9746e" alt="数据结构(C语言实现)"
上QQ阅读APP看书,第一时间看更新
3.1.4 链栈
1.栈的链式存储结构
采用链式存储方式的栈称为链栈或链式栈。由于栈的插入与删除操作仅限在表头的位置进行,因此链表的表头指针就作为栈顶指针。通常,链栈采用带头结点的单链表实现。如图3.5所示。
data:image/s3,"s3://crabby-images/7530e/7530e58d2b96630756cea9860d3307b1e3f7c0a1" alt=""
图3.5 链栈示意图
在图3.5中,top为栈顶指针,始终指向栈顶元素前面的头结点。链栈的基本操作与链表的类似,在使用完链栈时,应释放其空间。
链栈结点的类型描述如下:
data:image/s3,"s3://crabby-images/f9c66/f9c66ee1222f3b4cde8a8c1448f8b60463c075e4" alt=""
链栈的进栈操作与链表的插入操作类似,出栈操作与链表的删除操作类似。关于链栈的操作说明如下:
(1)链栈通过链表实现,链表的第一个结点位于栈顶,最后一个结点位于栈底。
(2)设栈顶指针为top,初始化时,对于不带头结点的链栈,top=NULL;对于带头结点的链栈,top->next=NULL。
(3)不带头结点的栈空条件为top==NULL,带头结点的栈空条件为top->next==NULL。
2.链栈的基本运算
链栈的基本运算具体实现如下(以下算法的实现保存在文件“LinkStack.h”中)。
(1)链栈的初始化。
data:image/s3,"s3://crabby-images/0b712/0b712dd2f8e87edff35440332a71725c3637ac93" alt=""
(2)判断链栈是否为空。
data:image/s3,"s3://crabby-images/ef011/ef0111ef04a8a20310a38f1d2bc1ad60de277334" alt=""
data:image/s3,"s3://crabby-images/125eb/125eb01e8d5acc80ec8d4dd5419285c8048208ea" alt=""
(3)进栈操作。进栈操作就是要将新元素结点插入到链表的第一个结点之前,分为两个步骤:①p->next=top->next;②top->next=p。进栈操作如图3.6所示。
data:image/s3,"s3://crabby-images/e4ed8/e4ed825f9cb868e25501994423f6241a02f49fda" alt=""
图3.6 进栈操作
data:image/s3,"s3://crabby-images/899dd/899dd099d4c4b376da41b8f2cf68c5813dbaf373" alt=""
(4)出栈操作。出栈操作就是将单链表中的第一个结点删除,并将结点的元素赋值给e,并释放结点空间。在元素出栈前,要判断栈是否为空。出栈操作如图3.7所示。
data:image/s3,"s3://crabby-images/b8041/b804120bca6a54d7b080eb6c35cb641d87c7feb3" alt=""
图3.7 出栈操作
data:image/s3,"s3://crabby-images/a6454/a6454ea0e18432a8102f788ecd6435c6bedd34e9" alt=""
data:image/s3,"s3://crabby-images/6d2eb/6d2eb0f57bc57f30ee6fb5888b0c09a9b72561a5" alt=""
(5)取栈顶元素。
data:image/s3,"s3://crabby-images/a6447/a644755b8a43b3bd54891ee20829b7b7f73f6e32" alt=""
(6)求表长操作。
data:image/s3,"s3://crabby-images/a91de/a91de0cb034eb4e5c3ccb253d75e8a6b754a72f1" alt=""
在链表中为了求表中元素个数,必须从栈顶指针出发,依次访问每个结点,并利用计数器计数,直到栈底为止。求表长的时间复杂度为O(n)。
(7)销毁链栈。
data:image/s3,"s3://crabby-images/f7e4a/f7e4a7756613c9305473e8033b2f2011a1dee32d" alt=""