数据结构【链栈】

devtools/2025/2/4 12:01:29/

基于 C++ 实现链表栈:原理、代码与应用

一、引言

栈就是一个容器,可以当场一个盒子,只能一个一个拿,一个一个放,而且是从上面放入。
有序顺序栈操作比较容易【会了链栈之后顺序栈自然明白】,所以我们这里只对链表进行详细解释。

二、栈的链表实现原理

链表是一种动态数据结构,由一系列节点组成,每个节点包含数据和指向下一个节点的指针。利用链表实现栈,就是将链表的头部作为栈顶,通过对链表头部的操作来模拟栈的入栈和出栈操作。这种实现方式的优点在于不需要预先分配固定大小的内存空间,能够根据实际需求动态调整栈的大小。

三、代码实现

1. 栈节点的定义

#include<iostream>
using namespace std;typedef struct stacknode {int date; // 存放数据struct stacknode* next; // 指针域
} lststack;lststack *S;

这里定义了一个名为 stacknode 的结构体,并重命名为 lststack。每个节点包含一个整数 date 用于存储数据,以及一个指向下一个节点的指针 next。同时,声明了一个全局的栈顶指针 S

2. 栈的初始化

lststack *initstack()
{ // 初始化lststack* S = NULL;return S;
}

initstack 函数用于初始化栈,将栈顶指针置为 NULL,表示栈为空。

3. 判断栈是否为空

int empty(lststack* S)
{if (S == NULL) return 1;else return 0;
}

empty 函数用于判断栈是否为空。如果栈顶指针为 NULL,则返回 1,表示栈为空;否则返回 0。

4. 入栈操作

lststack *push(lststack* s, int x)
{lststack* p = (lststack*)malloc(sizeof(lststack));p->date = x;p->next = s;s = p;return s;
}

push 函数用于将元素 x 压入栈中。具体步骤如下:

  • 使用 malloc 函数为新节点分配内存空间。
  • 将元素 x 赋值给新节点的 date 成员。
  • 让新节点的 next 指针指向原来的栈顶节点。
  • 更新栈顶指针为新节点。
  • 返回更新后的栈顶指针。

5. 出栈操作

lststack* pop(lststack* s, int *x)
{lststack* p = (lststack*)malloc(sizeof(lststack));if (empty(s)) {cout << "栈空了" << endl;return NULL;}*x = s->date;p = s;s = s->next;free(p);return s;
}

pop 函数用于将栈顶元素弹出栈。具体步骤如下:

  • 首先检查栈是否为空,如果为空则输出提示信息并返回 NULL
  • 将栈顶元素的值赋给指针 x 所指向的变量。
  • 用临时指针 p 指向栈顶节点。
  • 更新栈顶指针为原栈顶节点的下一个节点。
  • 释放原栈顶节点的内存空间。
  • 返回更新后的栈顶指针。

6. 查看栈顶元素

int top(lststack* s, int* x)
{lststack* p = (lststack*)malloc(sizeof(lststack));if (empty(s)) {cout << "栈空了" << endl;return 0;}*x = s->date;return 1;
}

top 函数用于查看栈顶元素的值。如果栈为空,则输出提示信息并返回 0;否则将栈顶元素的值赋给指针 x 所指向的变量,并返回 1。

7. 打印栈元素

void print(lststack* s)
{lststack* p = (lststack*)malloc(sizeof(lststack));p = s;if (empty(s)) {cout << "栈空了" << endl;return;}while (p){cout << p->date;p = p->next;}return;
}

print 函数用于遍历栈并打印每个元素的值。如果栈为空,则输出提示信息;否则从栈顶开始依次打印每个元素的值。

8. 主函数测试

在这里插入图片描述
结果如下:在这里插入图片描述

在主函数中,首先调用 initstack 函数初始化栈,然后使用 push 函数将元素 1、2、3、5 依次压入栈中,接着使用 print 函数打印栈中的元素,再使用 pop 函数弹出一个元素并打印弹出的元素的值,最后再次使用 print 函数打印栈中的元素。
`

五、总结

通过本文的介绍,我们学习了如何使用 C++ 语言,利用链表实现一个栈。这种实现方式具有动态调整大小的优点,适用于需要灵活管理内存的场景。同时,我们也对代码中存在的问题进行了分析,并给出了优化建议。在实际应用中,我们可以根据具体需求对代码进行进一步的扩展和优化。


http://www.ppmy.cn/devtools/155993.html

相关文章

构建一个数据分析Agent:提升分析效率的实践

在上一篇文章中,我们讨论了如何构建一个智能客服Agent。今天,我想分享另一个实际项目:如何构建一个数据分析Agent。这个项目源于我们一个金融客户的真实需求 - 提升数据分析效率,加快决策速度。 从分析师的痛点说起 记得和分析师团队交流时的场景&#xff1a; 小张&#xff…

Java 23新特性

文章目录 Java 23新特性一、引言二、Markdown文档注释&#xff08;JEP 467&#xff09;示例 三、ZGC&#xff1a;默认的分代模式&#xff08;JEP 474&#xff09;1. 为什么要引入分代模式2. 使用分代模式的优势3. 如何启用分代模式 四、隐式声明的类和实例主方法&#xff08;JE…

《苍穹外卖》项目学习记录-Day11订单统计

根据起始时间和结束时间&#xff0c;先把begin放入集合中用while循环当begin不等于end的时候&#xff0c;让begin加一天&#xff0c;这样就把这个区间内的时间放到List集合。 查询每天的订单总数也就是查询的时间段是大于当天的开始时间&#xff08;0点0分0秒&#xff09;小于…

【Elasticsearch】_rollover API详解

解释 POST logs-foo-bar/_rollover 在Elasticsearch中&#xff0c;POST logs-foo-bar/_rollover 是一个API调用&#xff0c;用于触发索引的滚动操作。滚动操作允许您在索引达到一定大小或时间限制时&#xff0c;自动将写入操作切换到一个新的索引&#xff0c;同时保留旧索引的…

无人机红外热成像:应急消防的“透视眼”

无人机红外热成像&#xff1a;应急消防的“透视眼” 亲爱的小伙伴们&#xff0c;每年一到夏天&#xff0c;应急消防的战士们就像上紧了发条的闹钟&#xff0c;时刻准备应对各种灾害。炎热天气让火灾隐患“蹭蹭”往上涨&#xff0c;南北各地还有防洪救灾、台风、泥石流等灾害轮…

【Three.js+React】教程002:添加lil-gui控制器和加载GLTF模型

文章目录 添加lil-gui加载gltf模型添加lil-gui 安装lil-gui: npm install lil-gui实现代码: function RotatingBox() {const meshRef = useRef();

半导体器件与物理篇7 微波二极管、量子效应和热电子器件

基本微波技术 微波频率&#xff1a;微波频率涵盖约从0.1GHz到3000GHz&#xff0c;相当于波长从300cm到0.01cm。 分布效应&#xff1a;电子部件在微波频率&#xff0c;与其在较低频率的工作行为不同。 输运线&#xff1a;一个由电阻、电容、电感三种等效基本电路部件所组成的…

4.[ISITDTU 2019]EasyPHP

进入题目页面如下 给出PHP源码进行代码审计 <?php // 高亮显示当前文件的源代码 highlight_file(__FILE__);// 从 GET 请求中获取名为 _ 的参数&#xff0c;并将其赋值给变量 $_ // 符号用于抑制可能出现的错误信息 $_ $_GET[_];// 使用正则表达式对 $_ 变量的值进行匹配…