c语言push_C语言栈的图文解析和实现

5a74273893222f3924f5c21f3ff40369.png

栈的介绍

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

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

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

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

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

  • peek——返回栈顶元素。

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

1. 栈的示意图

a9ac5edb670a3495b6d498e71dd2f159.png

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

2. 出栈

2d09551d4b6897322c76dcfdb2475dd4.png

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

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

3. 入栈

32868772e9dd9d02e29d71c47694269a.png

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

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

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

实现代码:

c55979fac1d5e84134a7821aa917b226.png

运行结果:

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数据

实现代码:

9908e489e6611e718cf0a1b1faceede2.png

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

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

实现代码:

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

fb1e3cc2d75d4f5c9a16b6966807985f.png

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

959fd8c7edb35ae8082b9d91440a7672.png

ffc97db35c61cc2530d9a37dda9c27f7.png

6f71493a41b05ce059bc001875354c59.png

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

a7a44ca58eb862a600c232046516f7b0.png

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

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

实现代码:

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

ef18d49a618a9a7f7e33cae09d96e4cf.png

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

56c627f9a54ec7e2ed69e7f973705141.png

c85de42b48064376bf41b3fad6704ad2.png

83ebaf9e4c977c8246d09632534d4aec.png

cc182debabae335860a7c6a828927eec.png

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

cfec3f267ba0b5e969cbb56a3dba6be0.png

运行结果:

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

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

-END-

来源:博客园,作者skywang12345 原文地址https://www.cnblogs.com/skywang12345/p/3562239.html 免责声明:整理本文出于传播相关技术知识,版权归原作者所有。
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值