任务描述
本关任务是实现 step2/LnkStack.cpp 中的LS_IsEmpty
、LS_Length
、LS_Push
、LS_Pop
和LS_Top
五个操作函数,以实现判断栈是否为空、求栈的长度、进栈、出栈以及获取栈顶元素等功能。
相关知识
链接存储的栈
栈的存储也可以采用链接存储的方式来实现。下面给出了一种基于链接存储的栈的实现方案:
如图 1 所示:该栈存储了 3 个元素 {56,77,15} ,其中 56 是栈顶元素。
这种实现方案中与栈相关的两个属性元素top
和len
介绍如下:
top
: 指向栈顶结点的指针;len
: 栈中结点的个数。
特别说明:链接存储方式下,链表头结点作为栈顶结点,用指针
top
指向栈顶结点,栈结点个数由len
给出。
基于top
和len
组织成的栈结构如下:
struct LinkStack {
LNode* top; // 栈顶指针
int len; // 栈的长度
};
为了讨论简单,我们假设栈元素的数据类型为整数:
typedef int T; // 栈元素的数据类型
同时,每个结点的结构定义为:
struct LNode {
T data;
LNode* next;
};
据此,只要给定指向该结构的一指针ls
,就可对栈进行出栈操作。
- 进行出栈操作时,将指针
top
指向的当前栈顶元素 56 出栈,出栈后top
指向下一个栈顶元素 77,这时的状态则如图 2 所示。
针对链式栈我们定义如下操作:
-
创建栈:创建一个链式栈。具体操作函数定义如下:
LinkStack* LS_Create()
; -
释放栈:释放栈所占用的空间。具体操作函数定义如下:
void LS_Free(LinkStack* ls)
; -
清空一个栈:将链式栈变为空栈。具体操作函数定义如下:
void LS_MakeEmpty(LinkStack