数据结构之堆,栈的实现

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

实现的功能如上图。

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

capacity表示栈的容量。

首先是堆的初始化

再就是栈的插入和删除

然后实现显示栈顶元素

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

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

下面是队列的实现

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

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

初始化的实现

尾插的实现。

尾删的实现。

整个队列销毁的实现

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

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

相关推荐
奔跑吧 android11 分钟前
【linux kernel 常用数据结构和设计模式】【数据结构 3】【模拟input子系统input_dev和input_handler之间的多对多关系】
linux·数据结构·input·kernel·input_dev·input_handler·input_handle
微露清风1 小时前
系统性学习数据结构-第三讲-栈和队列
java·数据结构·学习
lifallen2 小时前
Kafka 内存池MemoryPool 设计
数据结构·kafka·apache
一只鱼^_3 小时前
牛客周赛 Round 108
数据结构·c++·算法·动态规划·图论·广度优先·推荐算法
红豆怪怪4 小时前
[LeetCode 热题 100] 32. 最长有效括号
数据结构·python·算法·leetcode·动态规划·代理模式
AI 嗯啦5 小时前
计算机的排序方法
数据结构·算法·排序算法
_Coin_-5 小时前
算法训练营DAY58 第十一章:图论part08
数据结构·算法·图论
阿方.9185 小时前
《数据结构全解析:栈(数组实现)》
java·开发语言·数据结构
小欣加油7 小时前
leetcode 912 排序数组(归并排序)
数据结构·c++·算法·leetcode·排序算法
zl_dfq7 小时前
数据结构 之 【模拟实现哈希表】
数据结构