数据结构之堆,栈的实现

首先我们分析由于只需要尾进尾出,用数组模拟更简单。

实现的功能如上图。

top可以表示栈中元素个数。

capacity表示栈的容量。

首先是堆的初始化

再就是栈的插入和删除

然后实现显示栈顶元素

大小和检测是否为空的实现

销毁栈的实现(防止内存泄露)

下面是队列的实现

由于需要头出尾入,所有用链表实现更好。

为了避免每一次调用的时候还要输入头,尾指针,直接进行打包成结构体。

初始化的实现

尾插的实现。

尾删的实现。

整个队列销毁的实现

然后我们就要实现队列的头显和尾显已经判断是否为空的实现。

最后就是判断队列大小的实现。

相关推荐
Queenie_Charlie1 小时前
小陶与杠铃片
数据结构·c++·树状数组
云深处@2 小时前
【C++】AVL树
数据结构
Yvonne爱编码2 小时前
JAVA数据结构 DAY4-ArrayList
java·开发语言·数据结构
czxyvX4 小时前
016-二叉搜索树(C++实现)
开发语言·数据结构·c++
执着2594 小时前
力扣hot100 - 94、二叉树的中序遍历
数据结构·算法·leetcode
-dzk-4 小时前
【代码随想录】LC 707.设计链表
数据结构·c++·算法·链表
you-_ling5 小时前
数据结构:3.栈和队列
数据结构
梵刹古音6 小时前
【C语言】 递归函数
c语言·数据结构·算法
代码游侠7 小时前
C语言核心概念复习(二)
c语言·开发语言·数据结构·笔记·学习·算法
you-_ling7 小时前
数据结构:5.哈希表
数据结构·散列表