数据结构之堆,栈的实现

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

实现的功能如上图。

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

capacity表示栈的容量。

首先是堆的初始化

再就是栈的插入和删除

然后实现显示栈顶元素

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

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

下面是队列的实现

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

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

初始化的实现

尾插的实现。

尾删的实现。

整个队列销毁的实现

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

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

相关推荐
海清河晏11112 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
liulilittle12 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
Irissgwe13 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白13 小时前
数据容器集合set/frozenset
数据结构
代码中介商14 小时前
跳表:高效查找的链表黑科技
数据结构
SHARK_pssm16 小时前
【数据结构——树与堆】
c语言·数据结构·经验分享·笔记
RH23121117 小时前
2026.6.10 数据结构 二叉树
数据结构
CHHH_HHH18 小时前
【C++】哈希表原理与实战:从冲突解决到性能优化
开发语言·数据结构·c++·学习·算法·哈希算法·散列表
Irissgwe18 小时前
数据结构-排序
数据结构·算法·排序算法
青山木18 小时前
Hot 100 --- 滑动窗口最大值
java·数据结构·算法·leetcode·动态规划