(数据结构)栈的实现——再一次保姆级教学
目录
1. 栈
编辑
1.2 栈的实现
2. 代码的实现
2.1 初始化栈和销毁栈
2.2栈顶元素的插入
2.3栈顶元素的删除
栈元素删除
2.4栈顶元素的获取和栈元素的个数
1. 栈
1.1 栈的概念和结构
栈(Stack)是一种线性存储结构,它具有如下特点:
(1)栈中的数据元素遵守”先进后出”(First In Last Out)的原则,简称FILO结构。
(2)限定只能在栈顶进行插入和删除操作。
压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。
出栈:栈的删除操作叫做出栈。出数据也在栈顶
注意:我们在进行数据插入和删除操作中,都是在栈顶实现的,而另一端叫做栈底。
我们借用一下这个图来说明:
1.2 栈的实现
我们这里可以通过两种方法实现,顺序表或链表。
这里我们会发现链表要尾插或者尾删需要便利一遍链表,效率低;顺序表尾插尾删很快,但是还要解决扩容问题。
所以这里我们就引出了栈这个东西
2. 代码的实现
这里我们需要说明一下,之前我们在实现链表或者顺序表双向链表中都用的是size,为了更好的明确个数。
这里top指的是栈顶元素,如果初始化为 ” -1 “ ,指的是栈顶元素;如果为 “ 0 ” ,指的是栈顶的下一个元素。
这里面我建议是初始化为0:
- top还可以表示元素的个数,可以用来判断栈是否满了
- 插入元素的时候直接在top的位置插入就行,然后再top++即可

废话不多先来个头文件
typedef int STDataType;
typedef struct Stack
{STDataType* a;int top;int capacity;
}ST;void STInit(ST* pst);
void STDestroy(ST* pst);
void STPush(ST* pst, STDataType x);
void STPop(ST* pst);
STDataType STTop(ST* pst);
bool STEmpty(ST* pst);
int STSize(ST* pst);
2.1 初始化栈和销毁栈
我们首先要检查一下结构体是否为空,这里我们要注意一下
void STInit(ST* pst)
{assert(pst);pst->a = NULL;//pst->top = -1; // top 指向栈顶数据pst->top = 0; // top 指向栈顶数据的下一个位置pst->capacity = 0;
}
这里我们断言结构体不为空在继续,释放我们开辟的空间,将其他数据置为0
void STDestroy(ST* pst)
{assert(pst);free(pst->a);pst->a = NULL;pst->top = pst->capacity = 0;
}
2.2栈顶元素的插入
这里面我们要判断储存空间是否足够,如果没有开辟,我们可以先开辟一些空间出来;如果栈空间满了,直接将栈空间扩大二倍
void STPush(ST* pst, STDataType x)
{if (pst->top == pst->capacity){int newCapacity = pst->capacity == 0 ? 4 : pst->capacity * 2;STDataType* tmp = (STDataType*)realloc(pst->a, newCapacity * sizeof(STDataType));if (tmp == NULL){perror("realloc fail");return;}pst->a = tmp;pst->capacity = newCapacity;}pst->a[pst->top] = x;pst->top++;
}
2.3栈顶元素的删除
注意:当top为0,代表我们没有元素,不能再减下去,需要一个函数判断一下
判断函数
bool STEmpty(ST* pst)
{assert(pst);/*if (pst->top == 0){return true;}else{return false;}*/return pst->top == 0;
}
栈元素删除
void STPop(ST* pst)
{assert(pst);assert(!STEmpty(pst));pst->top--;
}
2.4栈顶元素的获取和栈元素的个数
这里面我们初始化为0,所以我们返回栈顶元素前一个元素即可;如果为空,需要我们断言一下
STDataType STTop(ST* pst)
{assert(pst);assert(!STEmpty(pst));return pst->a[pst->top - 1];
}
元素个数
int STSize(ST* pst)
{assert(pst);return pst->top;
}
以上就是今天栈实现的分享,如果喜欢的话请三联支持一下吧,感谢你的收看,我们下期再见!!!
相关文章:
(数据结构)栈的实现——再一次保姆级教学
目录 1. 栈 编辑 1.2 栈的实现 2. 代码的实现 2.1 初始化栈和销毁栈 2.2栈顶元素的插入 2.3栈顶元素的删除 栈元素删除 2.4栈顶元素的获取和栈元素的个数 1. 栈 1.1 栈的概念和结构 栈(Stack)是一种线性存储结构,它具有如下特点: ࿰…...
【5G RRC】RSRP、RSRQ以及SINR含义、计算过程详细介绍
博主未授权任何人或组织机构转载博主任何原创文章,感谢各位对原创的支持! 博主链接 本人就职于国际知名终端厂商,负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作,目前牵头6G算力网络技术标准研究。 博客…...
K8s(Kubernetes)学习(一):k8s概念及组件
Kubernetes中文文档:https://kubernetes.io/zh-cn/docs/home/ Kubernetes源码地址:https://github.com/kubernetes/kubernetes 一:Kubernetes是什么 首先要了解应用程序部署经历了以下几个时代: 传统部署时代:在物理服务器上运…...
Web3 常用语和黑话你知道吗?
My friend Dave used to be a bagholder, but he FOMO’d and bought even more BTC. Now, he’s a big whale HODLing for that moon. …that’s a lot to take in for just two sentences. If you’re new to Bitcoin and the world of cryptocurrencies, we understand if …...
物联网和边缘计算:如何将数据处理和决策推向设备边缘
第一章:引言 当我们谈论物联网(IoT)时,我们通常指的是将各种设备连接到互联网,并通过数据交换来实现智能化的网络。然而,传统的物联网模型通常涉及将数据发送到云端进行处理和分析。然而,随着技…...
【Android学习专题】java基本语法和概念(学习记录)
学习记录来自菜鸟教程 Java 变量 Java 中主要有如下几种类型的变量 局部变量 在方法、构造方法或者语句块中定义的变量被称为局部变量。变量声明和初始化都是在方法中,方法结束后,变量就会自动销毁类变量(静态变量) 类变量也声…...
Android系统启动全流程分析
当我们买了一个手机或者平板,按下电源键的那一刻,到进入Launcher,选择我们想要使用的某个App进入,这个过程中,系统到底在做了什么事,伙伴们有仔细的研究过吗?可能对于Framework这块晦涩难懂的专…...
RabbitMQ --- 惰性队列、MQ集群
一、惰性队列 1.1、消息堆积问题 当生产者发送消息的速度超过了消费者处理消息的速度,就会导致队列中的消息堆积,直到队列存储消息达到上限。之后发送的消息就会成为死信,可能会被丢弃,这就是消息堆积问题。 解决消息堆积有三种…...
1.Buffer_Overflow-1.Basic_Jump
github上面的练习题 git clone https://github.com/Adamkadaban/LearnPwn 然后开始做 先进行 readelf 然后进行执行看看 是怎么回事 ./buf1发现就是一个输入和输出 我们checksec看看 发现stack 保护关闭 开启了NX保护 我们进入ida64看看反汇编 我习惯先看看字符串 SHITF…...
MySQL入门语法第三课:表结构的创建
数据表结构 定点数类型decimal(m,d) m表示数字总位数 d表示小数位数 ★创建数据表先要选择数据库 1 . CREATE TABLE 表名称 创建数据表 (字段名1 数据类型1 [,字段名2 数据名2] [, .....] ); 一个字段写一行 修改表名 alter table 旧表名 rename 新表名…...
SpringSecurity框架学习与使用
SpringSecurity框架学习与使用 SpringSecurity学习SpringSecurity入门SpringSecurity深入认证授权自定义授权失败页面权限注解SecuredPreAuthorizePostAuthorizePostFilterPreFilter 参考 SpringSecurity学习 SpringSecurity入门 引入相关的依赖,SpringBoot的版本…...
DHCP+链路聚合+NAT+ACL小型实验
实验要求: 1.按照拓扑图上标识规划网络。 2.使用0SPF协议进程100实现ISP互通。 3.私网内PC属于VLAN1O, FTP Server属于VLAN2O,网关分 别为所连接的接入交换机,其中PC要求通过DHCP动态获取 4:私网内部所有交换机都为三层交换机,请合理规划VLAN&#…...
西瓜书读书笔记整理(三)—— 第二章 模型评估与选择
第二章 模型评估与选择 第 2 章 模型评估与选择2.1 经验误差与过拟合1. 错误率 / 精度 / 误差2. 训练误差 / 经验误差 / 泛化误差3. 过拟合 / 欠拟合4. 学习能力5. 模型选择 2.2 评估方法1. 评估方法概述2. 留出法3. 交叉验证法4. 自助法5. 调参 / 最终模型 2.3 性能度量1. 回归…...
AcWing算法提高课-1.3.6货币系统
宣传一下算法提高课整理 <— CSDN个人主页:更好的阅读体验 <— 本题链接(AcWing) 点这里 题目描述 给你一个n种面值的货币系统,求组成面值为m的货币有多少种方案。 输入格式 第一行,包含两个整数n和m。 接…...
vue3回到上一个路由页面
学习链接 Vue Router获取当前页面由哪个路由跳转 在Vue3的setup中如何使用this beforeRouteEnter 在这个路由方法中不能访问到组件实例this,但是可以使用next里面的vm访问到组件实例,并通过vm.$data获取组件实例上的data数据getCurrentInstance 是vue3提…...
Linux三种网络模式 | 仅主机、桥接、NAT
💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! Linux三种网络模式 仅主机模式:虚拟机只能访问物理机,不能上网 桥接模式:虚拟机和物理机连接同一网络,虚拟机和物理机…...
数据库设计与前端框架
数据库设计与前端框架 学习目标: 理解多租户的数据库设计方案 熟练使用PowerDesigner构建数据库模型理解前端工程的基本架构和执行流程 完成前端工程企业模块开发 多租户SaaS平台的数据库方案 多租户是什么 多租户技术(Multi-TenancyTechnology&a…...
技术探秘:揭秘Bean Factory与FactoryBean的区别!
大家好,我是小米,一个热衷于技术分享的29岁小编。今天,我们来聊一聊在Spring框架中常用的两个概念:beanFactory和FactoryBean。它们虽然看似相似,但实际上有着不同的用途和作用。让我们一起来揭开它们的神秘面纱吧&…...
MD-MTSP:遗传算法GA求解多仓库多旅行商问题(提供MATLAB代码,可以修改旅行商个数及起点)
一、多仓库多旅行商问题 多旅行商问题(Multiple Traveling Salesman Problem, MTSP)是著名的旅行商问题(Traveling Salesman Problem, TSP)的延伸,多旅行商问题定义为:给定一个𝑛座城市的城市集…...
技术面试的终极指南:助你取得成功的关键步骤
背景 技术面试是许多求职者最关键的一环,因为它评估了你在特定领域的知识和技能。无论你是刚毕业的大学应届生,还是有多年工作经验的职场老兵,准备充分是成功面试的关键。 这篇文章将提供一系列关键步骤,帮助你充分准备和展现自己…...
nanoMODBUS:为嵌入式系统量身打造的轻量级工业通信引擎
nanoMODBUS:为嵌入式系统量身打造的轻量级工业通信引擎 【免费下载链接】nanoMODBUS A compact MODBUS RTU/TCP C library for embedded/microcontrollers 项目地址: https://gitcode.com/gh_mirrors/na/nanoMODBUS 在资源受限的嵌入式世界中,工业…...
STM32F103RCT6驱动AD9833信号发生器:从SPI配置到波形输出的保姆级避坑指南
STM32F103RCT6驱动AD9833信号发生器:从SPI配置到波形输出的保姆级避坑指南 第一次用STM32驱动AD9833时,我盯着示波器上扭曲的波形发呆了半小时——明明代码和电路都照着参考设计做的,为什么输出的正弦波像被狗啃过一样?这个问题困…...
基于物联网技术的智慧餐厅管理系统设计与实现(有完整资料)
资料查找方式:特纳斯电子(电子校园网):搜索下面编号即可编号:T1032309M设计简介:本设计是基于物联网技术的智慧餐厅系统设计,主要实现以下功能:通过RFID感应模块通过对RFID卡进行监测…...
Windows 10下Veins+SUMO+OMNeT++环境搭建全攻略(避坑指南)
1. 环境准备:三大工具简介与版本选择 第一次接触车联网仿真时,我被VeinsSUMOOMNeT这个组合搞得晕头转向。后来才发现,这三个工具就像汽车工厂的三大部门:SUMO是道路规划师,负责构建交通场景;OMNeT是通信工…...
终极指南:如何用EZCard快速制作专业桌游卡牌,效率提升800%
终极指南:如何用EZCard快速制作专业桌游卡牌,效率提升800% 【免费下载链接】CardEditor 一款专为桌游设计师开发的批处理数值填入卡牌生成器/A card batch generator specially developed for board game designers 项目地址: https://gitcode.com/gh_…...
Lingbot-Depth-Pretrain-ViTL-14快速上手:Anaconda虚拟环境配置详解
Lingbot-Depth-Pretrain-ViTL-14快速上手:Anaconda虚拟环境配置详解 你是不是也遇到过这种情况:好不容易跟着教程装好了一个AI模型,结果运行的时候报了一堆错,不是这个库版本不对,就是那个依赖冲突。更头疼的是&#…...
MogFace镜像安全合规实践:纯本地运行杜绝隐私泄露,满足GDPR/等保2.0要求
MogFace镜像安全合规实践:纯本地运行杜绝隐私泄露,满足GDPR/等保2.0要求 在数据隐私和安全法规日益严格的今天,处理包含人脸等敏感信息的图像数据,正面临前所未有的合规挑战。无论是欧盟的《通用数据保护条例》(GDPR&…...
如何让微信聊天记录成为你的数字记忆银行?WeChatMsg终极指南
如何让微信聊天记录成为你的数字记忆银行?WeChatMsg终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we…...
Matlab实战:手把手教你用区域法(zonal method)重构波前相位(附完整代码)
Matlab实战:区域法波前重构技术详解与代码实现 在自适应光学系统中,波前重构是从斜率测量数据中恢复原始波前相位分布的核心技术。区域法(zonal method)因其计算效率高、实现简单等优势,成为工程实践中的首选方案。本文将深入解析Southwell和…...
004、规划模块(一):目标分解与任务规划基础
上周调一个机器人导航Agent,遇到个典型问题:我给它下指令“去三楼会议室拿一份资料”,结果这家伙直接往三楼冲,到了才发现会议室门锁着,又折回来找我要钥匙。整个过程像极了刚入行的程序员——只盯着最终目标ÿ…...

