数据结构之堆,栈的实现

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

实现的功能如上图。

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

capacity表示栈的容量。

首先是堆的初始化

再就是栈的插入和删除

然后实现显示栈顶元素

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

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

下面是队列的实现

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

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

初始化的实现

尾插的实现。

尾删的实现。

整个队列销毁的实现

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

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

相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎14 分钟前
C++哈希表
数据结构·c++·散列表
阿旭超级学得完1 小时前
C++11(初始化)
java·开发语言·数据结构·c++·算法
云淡风轻~窗明几净1 小时前
关于角谷猜想的五行小猜想
数据结构·算法
Languorous.2 小时前
C++数据结构进阶|并查集(Union-Find)详解:从原理到面试实战
数据结构·c++·面试
Languorous.2 小时前
C++数据结构进阶|堆(Heap)详解:从手写实现到面试高频实战
数据结构·c++·面试
玛卡巴卡ldf3 小时前
【LeetCode 手撕算法】(栈)有效括号、最小栈、字符串解码、每日温度、柱状图最大矩形
java·数据结构·算法·leetcode·力扣
我头发还没掉光~3 小时前
P4147 玉蟾宫
数据结构·c++·算法
枕星而眠4 小时前
栈(Stack)与队列(Queue)核心知识总结
c语言·数据结构·后端·链表
Little At Air4 小时前
LinuxOS阻塞队列模型(单生产者单消费者)
linux·数据结构·c++
铁皮哥5 小时前
【力扣题解】LeetCode 25. K 个一组翻转链表
java·数据结构·windows·python·算法·leetcode·链表