数据结构c++类模板实现动态数组_C/C++数据结构:栈结构解析,最简单解析,让你一遍就会...

8c222469-6913-eb11-8da9-e4434bdf6706.png

上一章节针对于C语言最基本的数据结构链式结构体做了解析,不清楚的可以回顾一下。本章节主要针对于C语言的基础数据结构栈做以解析。

数据结构之栈

栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

8d222469-6913-eb11-8da9-e4434bdf6706.png


故栈基本操作如下:

(1)创建栈

(2)入栈

(3)出栈

(4)判断栈是否为NULL

(5)返回栈顶元素

数据结构之栈分类

根据实现栈的方式,我们可以把栈分为以下三种描述方式:

原生数组描述

动态申请内存的数组描述

链式结构描述

原生数组描述栈

数组描述栈,只不过多了后进先出的限制而已,它是静态分配的,即使用前,它的内存就已经以数组的形式分配好了,所以在使用时,需要注意栈顶标记的大小。

举个例子,把十进制的数字5转二进制的数字,过程大概是这样:

8e222469-6913-eb11-8da9-e4434bdf6706.png


原生数组描述栈实现进制转换代码

90222469-6913-eb11-8da9-e4434bdf6706.png

动态数组实现栈

动态申请内存的数组描述不在采用上述实用性的方法了,而是通过封装相关栈函数去描述这种结构。这是写数据结构的一种大致方法。

1.结构体定义与栈的创建过程:

结构体定义:描述栈的属性栈:栈容量,栈顶标记

创建栈其实就是创建结构体变量

具体代码

93222469-6913-eb11-8da9-e4434bdf6706.png

ps:栈顶标记初始值一般都是-1 ,为了满足栈顶标记和数组下标一致

2.入栈操作

注意: 我们的实现是将最新的元素放在了数组的末尾, 那么数组末尾的元素就是我们的栈顶元素,故可以使用栈顶标记去计算栈中的元素个数。然后每次入栈后,栈顶标记往后移动。

具体实现代码:

94222469-6913-eb11-8da9-e4434bdf6706.png

3.出栈操作和获取栈顶元素

注意: 出栈操作应该是将栈顶的元素删除,由于数组实现的栈无法删除,故只能吧栈顶标记往前移动,简称为一种"伪删除"。

具体实现代码:

95222469-6913-eb11-8da9-e4434bdf6706.png

4.判断栈是否为空

用户判断栈中是否有元素,通过栈顶标记去做即可

具体实现代码:

97222469-6913-eb11-8da9-e4434bdf6706.png

动态申请内存的数组描述栈实现进制转换代码

99222469-6913-eb11-8da9-e4434bdf6706.png

链式栈

链式栈:链表的头插法即可

9a222469-6913-eb11-8da9-e4434bdf6706.png


这个不做详细分析了,希望对大家有帮助!

另外如果你想更好的提升你的编程能力,学好C语言C++编程!弯道超车,快人一步!

C语言C++编程学习:

点击领取C/C++编程学习资料​jq.qq.com

分享(源码、项目实战视频、项目笔记,基础入门教程)

欢迎转行和学习编程的伙伴,利用更多的资料学习成长比自己琢磨更快哦!

编程学习软件分享:

9b222469-6913-eb11-8da9-e4434bdf6706.png

编程学习视频分享:

9c222469-6913-eb11-8da9-e4434bdf6706.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值