数据结构–栈的链式存储
推荐使用不带头结点的单链表 \color{green}推荐使用不带头结点的单链表 推荐使用不带头结点的单链表
typedef struct LNode
{
ElemType data;
struct LNode* next;
} LNode, *LinkList;
bool InitList(LinkList &L)
{
L->next = NULL;
}
后插操作:在p结点之后插入元素e
bool InsertNextNode(LNode* p, ElemType e)
{
if (p == NULL) return false;
LNode* q = (LNode*)malloc(sizeof(LNode));
if (q == NULL) return false;
q->next = p->next;
q->data = e;
p->next = q;
}
进栈操作
等价于:头结点后插操作
头插法建立单链表
bool InitStackList(LinkList &L)
{
InitList(L);
while (循环)
{
//获取数据元素e
InsertNextNode(L, e);
}
}
对头结点的后删操作
bool DeleteNode(LNode* p)
{
if (p == NULL) return false;
LNode* q = p->next;
p->data = p->next->data;
p->next = q->next;
free(q);
return true;
}
出栈操作
等价于:对头结点的后删操作
bool Pop(LinkList &L)
{
DeleteNode(L, L);
}
整体代码
#include <stdio.h>
#include <stdlib.h>
// 定义链表节点结构体
typedef struct Node {
int data; // 数据域
struct Node* next; // 指针域,指向下一个节点
} Node;
// 进栈操作
Node* push(Node* top, int value) {
// 创建新节点
Node* newNode = (Node*)malloc(sizeof(Node));
newNode->data = value;
newNode->next = top;
// 返回新的栈顶节点
return newNode;
}
// 出栈操作
Node* pop(Node* top, int* value) {
// 如果栈为空,返回NULL
if (top == NULL) {
return NULL;
}
// 取出栈顶节点的值
*value = top->data;
// 将栈顶节点指向下一个节点
Node* temp = top;
top = top->next;
// 释放原栈顶节点的内存空间
free(temp);
// 返回新的栈顶节点
return top;
}
int main() {
Node* top = NULL; // 栈顶节点初始化为空
// 进栈操作
top = push(top, 1);
top = push(top, 2);
top = push(top, 3);
// 出栈操作
int value;
top = pop(top, &value);
printf("%d\n", value); // 输出3
top = pop(top, &value);
printf("%d\n", value); // 输出2
top = pop(top, &value);
printf("%d\n", value); // 输出1
top = pop(top, &value); // 栈已空,返回NULL
return 0;
}