当前位置:首页 > 公众号精选 > 21ic电子网
[导读]栈的介绍 栈(stack),是一种线性存储结构,它有以下几个特点: 栈中数据是按照"后进先出(LIFO, Last In First Out)"方式进出栈的。 向栈中添加/删除数据时,只能从栈顶进行操作。 栈通常包括的三种操作:push、peek、pop。 push——向栈中添加元素。 peek

C语言栈的图文解析和实现


栈的介绍



栈(stack),是一种线性存储结构,它有以下几个特点:

  • 栈中数据是按照"后进先出(LIFO, Last In First Out)"方式进出栈的。

  • 向栈中添加/删除数据时,只能从栈顶进行操作。


栈通常包括的三种操作:push、peek、pop。

  • push——向栈中添加元素。

  • peek——返回栈顶元素。

  • pop——返回并删除栈顶元素的操作。


1. 栈的示意图


C语言栈的图文解析和实现


栈中的数据依次是30→20→10。


2. 出栈


C语言栈的图文解析和实现


出栈前:栈顶元素是30。此时,栈中的元素依次是30→20→10。


出栈后:30出栈之后,栈顶元素变成20。此时,栈中的元素依次是20→10。


3. 入栈


C语言栈的图文解析和实现


入栈前:栈顶元素是20。此时,栈中的元素依次是20→10。


入栈后:40入栈之后,栈顶元素变成40。此时,栈中的元素依次是 40→20→10。



栈的C实现



1
数组实现的栈,并且只能存储int数据


实现代码:


C语言栈的图文解析和实现


运行结果:


tmp=30tmp=20stack size()=3402010


结果说明:该示例中的栈,是通过"数组"来实现的!


由于代码中已经给出了详细了注释,这里就不再对函数进行说明了。仅对主函数main的逻辑进行简单介绍:

  • 在主函数main中,先将 "10, 20, 30"依次压入栈。此时,栈的数据是:30→20→10。

  • 接着通过pop()返回栈顶元素;pop()操作并不会改变栈中的数据。此时,栈的数据依然是:30→20→10。

  • 接着通过peek()返回并删除栈顶元素。peek操作之后,栈的数据是:20→10。接着通过push(40)将40压

  • 入栈中。push(40)操作之后,栈的数据是:40→20→10。


2
单向链表实现的栈,并且只能存储int数据


实现代码:


C语言栈的图文解析和实现


代码说明:"运行结果" 以及 "主函数main的逻辑"都和"C语言实现一"的一样。不同的是,该示例中的栈是通过单向链表实现的。


3
双向链表实现的栈,并且只能存储int数据


实现代码:


(1)双向链表的头文件(double_link.h)


C语言栈的图文解析和实现


(2)双向链表的实现文件double_link.c)


C语言栈的图文解析和实现

C语言栈的图文解析和实现

C语言栈的图文解析和实现


(3)双向链表的测试程序(dlink_stack.c)


C语言栈的图文解析和实现


代码说明:"运行结果" 以及 "主函数main的逻辑"都和前两个示例的一样。不同的是,该示例中的栈是通过双向链表实现的。


4
双向链表实现的栈,能存储任意类型的数据


实现代码:


(1)双向链表的头文件(double_link.h)


C语言栈的图文解析和实现


(2)双向链表的实现文件(double_link.c)


C语言栈的图文解析和实现

C语言栈的图文解析和实现

C语言栈的图文解析和实现

C语言栈的图文解析和实现


(3)双向链表的测试程序(dlink_stack.c)


C语言栈的图文解析和实现


运行结果:


id=40, name=danid=20, name=jodyid=10, name=sky


结果说明:该示例中的栈是通过双向链表实现的,并且能存储任意类型的数据。示例中是以结构体类型的数据进行演示的,由于代码中已经给出了详细的注释,这里就不再介绍了。


-END-


来源:博客园,作者skywang12345
原文地址https://www.cnblogs.com/skywang12345/p/3562239.html
免责声明:整理本文出于传播相关技术知识,版权归原作者所有。


免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

21ic电子网

扫描二维码,关注更多精彩内容

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭