队列链式存储 - 设计与实现 - API函数
队列相关基础内容参我的博文:队列顺序存储 - 设计与实现 - API函数
队列也是一种特殊的线性表;可以用线性表链式存储来模拟队列的链式存储。
主要代码:
// linkqueue.h // 队列链式存储API声明 #ifndef _LINKQUEUE_H_ #define _LINKQUEUE_H_ typedef void LinkQueue; // 创建队列 LinkQueue* LinkQueue_Create(); // 销毁队列 void LinkQueue_Destroy(LinkQueue* queue); // 清空队列 void LinkQueue_Clear(LinkQueue* queue); // 入队列 int LinkQueue_Append(LinkQueue* queue, void* item); // 出队列 void* LinkQueue_Retrieve(LinkQueue* queue); // 获取对头元素 void* LinkQueue_Header(LinkQueue* queue); // 获取队列长度 int LinkQueue_Length(LinkQueue* queue); #endif //_MY_LINKQUEUE_H_
// linkqueue.cpp // 队列链式存储API实现 // 调用了链式存储线性表 #include <stdio.h> #include "linkqueue.h" #include "linklist.h" #include <malloc.h> typedef struct _tag_LinkQueue { LinkListNode node; void* item; }TLinkQueue; // 创建队列相当于创建链表 LinkQueue* LinkQueue_Create() { return LinkList_Create(); } // 销毁队列相当于创建链表 void LinkQueue_Destroy(LinkQueue* queue) { LinkQueue_Clear(queue); LinkList_Destroy(queue); } // 清空队列相当于清空链表 void LinkQueue_Clear(LinkQueue* queue) { while (LinkQueue_Length(queue)) { LinkQueue_Retrieve(queue); } } // 入队列相当于在链表尾部插入元素 int LinkQueue_Append(LinkQueue* queue, void* item) { TLinkQueue *tmp = NULL; int ret = 0; tmp = (TLinkQueue *)malloc(sizeof(TLinkQueue)); if (tmp == NULL) { // 分配失败 return -1; } tmp->item = item; ret = LinkList_Insert(queue, (LinkListNode *)tmp, LinkList_Length(queue)); if (ret) { printf("function LinkQueue_Append err: %d\n", ret); free(tmp); return ret; } return ret; } // 出队列相当于删除链表0号位置的元素 void* LinkQueue_Retrieve(LinkQueue* queue) { TLinkQueue *tmp = NULL; void* item = NULL; tmp = (TLinkQueue *)LinkList_Delete(queue, 0); if (tmp == NULL) { return NULL; } item = tmp->item; free(tmp); // 不要忘记出队列的时候释放结点 return item; } // 获取队头元素相当于获取链表0号位置元素 void* LinkQueue_Header(LinkQueue* queue) { TLinkQueue *tmp = NULL; tmp = (TLinkQueue *)LinkList_Get(queue, 0); if (tmp == NULL) { return NULL; } return tmp->item; } // 获取队列长度 int LinkQueue_Length(LinkQueue* queue) { return LinkList_Length(queue); }
// main.cpp // 队列链式存储API测试程序 #include <stdio.h> #include "linkqueue.h" const int maxn = 10; void play() { int i = 0, a[maxn]; LinkQueue *lq = NULL; for (i = 0; i < maxn; ++i) { a[i] = i + 1; } lq = LinkQueue_Create(); // 创建队列 // 入队列 for (i = 0; i < maxn; ++i) { LinkQueue_Append(lq, &a[i]); } // 队列属性 printf("header: %d\n", *((int *)LinkQueue_Header(lq))); printf("length: %d\n", LinkQueue_Length(lq)); // 出队列 while (LinkQueue_Length(lq)) { int tmp = *((int *)LinkQueue_Retrieve(lq)); printf("%d\n", tmp); } // 销毁队列 LinkQueue_Destroy(lq); } int main() { play(); return 0; }
有关顺序存储表的相关内容,请参看我的另一篇博文线性表的顺序存储设计和实现 - API函数实现
相关工程代码:Github
队列链式存储 - 设计与实现 - API函数的更多相关文章
- 线性表链式存储设计与实现 - API实现
基本概念 链式存储定义 为了表示每个数据元素与其直接后继元素之间的逻辑关系,每个元素除了存储本身的信息外,还需要存储指示其直接后继的信息. 表头结点 链表中的第一个结点,包含指向第一个数据元素的指针以 ...
- 栈的链式存储 - API实现
基本概念 其它概念详情參看前一篇博文:栈的顺序存储 - 设计与实现 - API实现 这里也是运用了链表的链式存储API高速实现了栈的API. 代码: // linkstack.h // 链式存储栈的A ...
- C++编程练习(6)----“实现简单的队列的链式存储结构“
队列的链式存储结构,其实就是线性表的单链表,只不过它只能尾进头出.简称链队列. 实现代码如下: /* LinkQueue.h 头文件 */ #include<iostream> #defi ...
- 队列(FIFO)—循环队列、队列的链式存储
1 队列的定义 队列是只允许在一端(队尾)进行插入操作,而在另一端(队头)进行删除操作的线性表. 2 队列的特点 1)先进先出是队列最大的特点,是应用中非常常见的模型,例如排队: 2)队列也属于线性表 ...
- 队列的顺序存储与链式存储c语言实现
一. 队列 1.队列定义:只允许在表的一端进行插入,表的另一端进行删除操作的线性表. 2.循环队列:把存储队列的顺序队列在逻辑上视为一个环. 循环队列状态: 初始时:Q.front=Q.rear=0 ...
- [置顶] ※数据结构※→☆线性表结构(queue)☆============优先队列 链式存储结构(queue priority list)(十二)
优先队列(priority queue) 普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除.在优先队列中,元素被赋予优先级.当访问元素时,具有最高优先级的元素最先删除.优先队列具有 ...
- Java实现链式存储的二叉查找树(递归方法)
二叉查找树的定义: 二叉查找树或者是一颗空树,或者是一颗具有以下特性的非空二叉树: 1. 若左子树非空,则左子树上所有节点关键字值均小于根节点的关键字: 2. 若右子树非空,则右子树上所有节点关键字值 ...
- Java实现链式存储的二叉树
二叉树的定义: 二叉树(BinaryTree)是n(n≥0)个结点的有限集,它或者是空集(n=0),或者由一个根结点及两棵互不相交的.分别称作这个根的左子树和右子树的二叉树组成. 二叉树的遍历方式主要 ...
- C#数据结构-二叉树-链式存储结构
对比上一篇文章"顺序存储二叉树",链式存储二叉树的优点是节省空间. 二叉树的性质: 1.在二叉树的第i层上至多有2i-1个节点(i>=1). 2.深度为k的二叉树至多有2k- ...
随机推荐
- Java异常处理-----抛出处理
抛出处理 定义一个功能,进行除法运算例如(div(int x,int y))如果除数为0,进行处理. 功能内部不想处理,或者处理不了.就抛出使用throw new Exception("除数 ...
- C语言如何在两个文件中访问同一个全局变量
方法一: 不使用头文件. 1.c 中 int var; 2.c 中 extern int var; 方法二: 使用头文件. 1.c 中 int var; 不必添加#include "1.h& ...
- SVN与eclipse整合与使用、SVN与Apache整合
SVN与eclipse整合 下载SVN插件(http://subclipse.tigris.org) http://subclipse.tigris.org/servlets/ProjectDocum ...
- Combiners和Partitioner编程
Combiners的作用: 每一个map可能会产生大量的输出,combiner的作用就是在map端对输出先做一次合并,以减少传输到reducer的数据量. combiner最基本是实现本地key的归并 ...
- Android优化之ViewPager的懒加载
转载本博客请注明出处:点击打开链接 http://blog.csdn.net/qq_32059827/article/details/52487794 出于对用户消耗流量的考虑,有必要对view ...
- Maven 介绍、安装使用
简介 Maven是一个强大的构建工具,能够帮我们自动化构建过程,从清理.编译.测试到生成报告,再到打包和部署.只要使用Maven配置好项目,然后执行命令(如mvn clean inst ...
- 3、Android构建仪表测试
不同于运行于JVM的本地单元测试,仪表测试运行于你的物理设备或虚拟机中.当你需要访问设备的信息(比如Context)或者使用真正的Android framework组件时(比如SharePrefere ...
- TortoiseSVN服务器ip地址修改后如何使用
TortoiseSVN是很多人特别是程序员经常使用的工作追述工具,在长期使用过程中难免会遇到服务器迁移ip地址变更的问题.那么在服务器ip地址变化之后,我们要如何继续使用呢?步骤其实非常简单,下面我们 ...
- Aandroid TV 基于Leanback支持最新MD设计的TV开发框架
原文地址:http://blog.csdn.net/sk719887916 作者:skay 基于6.0最新的API 支持TV的框架 Android 6.0已完美支持TV开发,之前的5.0后Recycl ...
- [GitHub]第五讲:团队合作流程
文章转载自:http://blog.csdn.net/loadsong/article/details/51591631 前几天还都是一个开发者唱独角戏.但是尽管如此也可以看出 Git 带来的便利了, ...