上一章节针对于C语言最基本的数据结构链式结构体作了解析,不清楚的能够回顾一下。本章节主要针对于C语言的基础数据结构栈作以解析。编程
栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操做的线性表。这一端被称为栈顶,相对地,把另外一端称为栈底。向一个栈插入新元素又称做进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称做出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。数组
故栈基本操做以下:微信
(1)建立栈数据结构
(2)入栈函数
(3)出栈学习
(4)判断栈是否为NULL视频
(5)返回栈顶元素blog
根据实现栈的方式,咱们能够把栈分为如下三种描述方式:教程
原生数组描述内存
动态申请内存的数组描述
链式结构描述
数组描述栈,只不过多了后进先出的限制而已,它是静态分配的,即便用前,它的内存就已经以数组的形式分配好了,因此在使用时,须要注意栈顶标记的大小。
举个例子,把十进制的数字5转二进制的数字,过程大概是这样:
原生数组描述栈实现进制转换代码
动态申请内存的数组描述不在采用上述实用性的方法了,而是经过封装相关栈函数去描述这种结构。这是写数据结构的一种大体方法。
1.结构体定义与栈的建立过程:
结构体定义:描述栈的属性栈:栈容量,栈顶标记
建立栈其实就是建立结构体变量
具体代码
ps:栈顶标记初始值通常都是-1 ,为了知足栈顶标记和数组下标一致
2.入栈操做
注意: 咱们的实现是将最新的元素放在了数组的末尾, 那么数组末尾的元素就是咱们的栈顶元素,故可使用栈顶标记去计算栈中的元素个数。而后每次入栈后,栈顶标记日后移动。
具体实现代码:
3.出栈操做和获取栈顶元素
注意: 出栈操做应该是将栈顶的元素删除,因为数组实现的栈没法删除,故只能吧栈顶标记往前移动,简称为一种"伪删除"。
具体实现代码:
4.判断栈是否为空
用户判断栈中是否有元素,经过栈顶标记去作便可
具体实现代码:
动态申请内存的数组描述栈实现进制转换代码
链式栈
链式栈:链表的头插法便可
这个不作详细分析了,但愿对你们有帮助!
另外若是你想更好的提高你的编程能力,学好C语言C++编程!弯道超车,快人一步!
C语言C++编程学习交流圈子,QQ群757874045【点击进入】微信公众号:C语言编程学习基地
分享(源码、项目实战视频、项目笔记,基础入门教程)
欢迎转行和学习编程的伙伴,利用更多的资料学习成长比本身琢磨更快哦!
编程学习软件分享:
编程学习视频分享: