数据结构之堆,栈的实现

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

数据结构之堆,栈的实现_第1张图片

实现的功能如上图。

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

capacity表示栈的容量。
首先是堆的初始化

数据结构之堆,栈的实现_第2张图片

再就是栈的插入和删除

数据结构之堆,栈的实现_第3张图片

数据结构之堆,栈的实现_第4张图片

然后实现显示栈顶元素

数据结构之堆,栈的实现_第5张图片

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

数据结构之堆,栈的实现_第6张图片

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

数据结构之堆,栈的实现_第7张图片

下面是队列的实现

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

数据结构之堆,栈的实现_第8张图片

数据结构之堆,栈的实现_第9张图片

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

初始化的实现

数据结构之堆,栈的实现_第10张图片

尾插的实现。

数据结构之堆,栈的实现_第11张图片

尾删的实现。

数据结构之堆,栈的实现_第12张图片

整个队列销毁的实现

数据结构之堆,栈的实现_第13张图片

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

数据结构之堆,栈的实现_第14张图片

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

数据结构之堆,栈的实现_第15张图片

你可能感兴趣的:(数据结构)