数据结构之堆,栈的实现

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

实现的功能如上图。

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

capacity表示栈的容量。

首先是堆的初始化

再就是栈的插入和删除

然后实现显示栈顶元素

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

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

下面是队列的实现

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

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

初始化的实现

尾插的实现。

尾删的实现。

整个队列销毁的实现

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

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

相关推荐
酿情师2 小时前
区块链原理与技术02:区块链的数据结构04(区块结构)
数据结构·区块链
夏日听雨眠3 小时前
数据结构(循环队列)
数据结构·算法·链表
平行侠3 小时前
30MacLaren-Marsaglia算法故事文件
数据结构·算法
平行侠4 小时前
33水库抽样 - 从未知大小的流中等概率采样
数据结构·算法
Controller-Inversion4 小时前
42. 接雨水
数据结构·算法·leetcode
Controller-Inversion4 小时前
33. 搜索旋转排序数组
数据结构·算法·leetcode
宵时待雨5 小时前
优选算法专题6:模拟
数据结构·c++·算法·leetcode·职场和发展
Liangwei Lin5 小时前
LeetCode 35. 搜索插入位置
数据结构·算法·leetcode
L_09075 小时前
【C++】STL— 封装红黑树以实现map 和 set
数据结构·c++
此生决int5 小时前
快速复习之数据结构篇——二叉树(三)
数据结构