一个能够自动扩容的顺序结构的队列 ArrQueue (GCC编译)。

 /**
* @brief C语言顺序结构队列的实现
* @author wid
* @date 2013-10-30
*
* @note 若代码存在 bug 或程序缺陷, 请留言反馈, 谢谢!
*/ #include <stdio.h>
#include <stdlib.h> #define TRUE 1
#define FALSE 0 typedef struct Point2D
{
int x;
int y;
}ElemType; //元素结构 typedef struct
{
ElemType **rear; //队尾
ElemType *front; //队头
int len; //队列长度
int size; //队列总容量
}ArrQueue; //队列结构 //声明队列方法 ArrQueue *CreateQueue( int nLen ); //创建初始长度为 nLen 队列
void DestroyQueue( ArrQueue *pQueue ); //销毁队列pQueue
void ClearQueue( ArrQueue *pQueue ); //清空队列内元素
int GetLength( ArrQueue *pQueue ); //获取队列长度
int GetSize( ArrQueue *pQueue ); //获取队列总容量
int IsEmpty( ArrQueue *pQueue ); //检测队列是否为空
int GetHead( ArrQueue *pQueue, ElemType **pe ); //获取队头元素
int EnQueue( ArrQueue *pQueue, ElemType *pe ); //将元素插入到队尾
int DeQueue( ArrQueue *pQueue, ElemType **pe ); //将队头元素出队
void ForEachQueue( ArrQueue *pQueue, void (*func)(ElemType *pe) ); //从对尾到队头依次执行 func //队列方法实现 /**
* @brief 创建初始长度为 nLen 的队列
*
* @param nLen 队列的初始长度
*
* @return 返回指向新创建的队列的指针
*/
ArrQueue *CreateQueue( int nLen )
{
ArrQueue *pQueue = (ArrQueue *)malloc( sizeof(ArrQueue) );
pQueue->rear = (ElemType **)calloc( nLen, sizeof(ElemType **) );
pQueue->front = pQueue->rear[];
pQueue->len = ;
pQueue->size = nLen; return pQueue;
} /**
* @brief 销毁队列
*
* @param pQueue 指向待销毁的队列的指针
*/
void DestroyQueue( ArrQueue *pQueue )
{
free( pQueue->rear );
free( pQueue ); pQueue = NULL;
} /**
* @brief 清空队列内元素
*/
void ClearQueue( ArrQueue *pQueue )
{
pQueue->front = pQueue->rear[]; pQueue->len = ;
} /**
* @brief 获取队列长度
*
* @param 指向待获取长度的队列的指针
*
* @return 返回队列当前长度
*/
int GetLength( ArrQueue *pQueue )
{
return pQueue->len;
} /**
* @brief 获取队列总容量
*
* @param pQueue 指向待获取容量的队列
*
* @return 返回队列当前总容量
*/
int GetSize( ArrQueue *pQueue )
{
return pQueue->size;
} /**
* @brief 检测队列是否为空
*
* @param pQueue 指向待检测的队列
*
* @return 若为空, 则返回 TRUE, 否则返回 FALSE
*/
int IsEmpty( ArrQueue *pQueue )
{
return pQueue->len == ? TRUE : FALSE;
} /**
* @brief 获取队头元素
*
* @param pQueue 指向待获取队头元素的队列
*
* @param pe 指向接收元素的指针的指针
*
* @return 返回队头在队列中的位置(位置由 0 计起)
*/
int GetHead( ArrQueue *pQueue, ElemType **pe )
{
if( pQueue->len == )
{
*pe = NULL;
return -;
} *pe = pQueue->rear[pQueue->len-]; return pQueue->len-;
} /**
* @brief 将元素 pe 插入到队尾
*
* @param pQueue 指向待插入元素的队列
* @param pe 指向待插入的元素
*
* @return 返回成功插入后队列的长度
*/
int EnQueue( ArrQueue *pQueue, ElemType *pe )
{
///检测是否需要扩容
if( pQueue->len == pQueue->size )
{ //需要扩容
pQueue->rear = realloc( pQueue->rear, * pQueue->size * sizeof(ElemType *) );
pQueue->size = * pQueue->size;
} int i = ;
for( i = pQueue->len; i > ; --i )
{
pQueue->rear[i] = pQueue->rear[i-];
}
pQueue->rear[] = pe;
pQueue->front = pQueue->rear[pQueue->len]; return ++pQueue->len;
} /**
* @brief 将队头元素出队
*
* @param pQueue 指向待出队的队列
* @param pe 指向接收元素的指针的指针
*
* @return 成功出队则返回出队后队列的长度, 否则返回 -1
*/
int DeQueue( ArrQueue *pQueue, ElemType **pe )
{
if( pQueue->len == )
{
*pe = NULL;
return -;
}
*pe = pQueue->front;
--pQueue->len;
pQueue->front = pQueue->rear[pQueue->len-]; return pQueue->len;
} /**
* @brief 从队尾到队头每个元素一次执行 func
*
* @param pQueue 指向待处理的队列
* @param func 回调函数指针
*/
void ForEachQueue( ArrQueue *pQueue, void (*func)(ElemType *pe) )
{
int i = ;
for( i = ; i < pQueue->len; ++i )
{
func( pQueue->rear[i] );
}
} //测试
void display( ElemType *pe )
{
printf( "(%d,%d) ", pe->x, pe->y );
} int main()
{
ElemType t1 = {, };
ElemType t2 = {, };
ElemType t3 = {, };
ElemType t4 = {, };
ElemType t5 = {, }; ///测试 CreateQueue
ArrQueue *pque = CreateQueue( ); ///测试入队
EnQueue( pque, &t1 );
EnQueue( pque, &t2 );
EnQueue( pque, &t3 );
EnQueue( pque, &t4 );
EnQueue( pque, &t5 ); ///测试 ForEachQueue
ForEachQueue( pque, display ); ///测试 IsEmpty、GetSize、GetLength
if( IsEmpty( pque ) != TRUE )
printf( "\n队列总容量:%d, 当前长度:%d\n", GetSize(pque), GetLength(pque) ); ///测试全部出队
printf( "\n测试全部出队:\n" );
ElemType *p;
while( DeQueue( pque, &p ) != - )
{
printf( "当前出队:(%d,%d), 剩余队列长为:%d\n", p->x, p->y, GetLength(pque) );
} ///测试 ClearQueue
printf( "\n再次入队2元素..\n" );
EnQueue( pque, &t1 );
EnQueue( pque, &t2 );
ForEachQueue( pque, display );
printf( "\n清空队列..\n" );
ClearQueue( pque );
printf( "队列总容量:%d, 当前长度:%d\n", GetSize(pque), GetLength(pque) ); ///测试 GetHead
printf( "\n再次入队2元素..\n" );
EnQueue( pque, &t1 );
EnQueue( pque, &t2 );
ForEachQueue( pque, display );
GetHead( pque, &p );
printf( "\n获取队头元素:(%d,%d)\n", p->x, p->y );
printf( "队列总容量:%d, 当前长度:%d\n", GetSize(pque), GetLength(pque) ); ///销毁队列
DestroyQueue( pque ); return ;
}

测试运行:

若代码存在 bug 或程序缺陷, 请留言反馈, 谢谢。                                                                                                                                                                                                                                                                                                                                                       

C语言 队列 顺序结构 实现的更多相关文章

  1. C语言 串 顺序结构 实现

    一个能够自动扩容的顺序结构的串 ArrString (GCC编译). /** * @brief C语言 串 顺序结构 实现 * @author wid * @date 2013-11-01 * * @ ...

  2. C语言 栈 顺序结构 实现

    一个能够自动扩容的顺序结构的栈 ArrStack 实例 (GCC编译). /** * @brief C语言实现的顺序结构类型的栈 * @author wid * @date 2013-10-29 * ...

  3. C语言之顺序结构

    该章内容:这章我们学习三大结构之一:顺序结构,它是程序从上往下顺序执行,是程序运行最简单的方式.printf和scanf函数使用和特例是必考知识.本章是考试的重点章节. 学习方法:从简单的顺序结构题目 ...

  4. (七)C语言之顺序结构

  5. Java 流程控制语句 之 顺序结构

    在一个程序执行的过程中,各条语句的执行顺序对程序的结果是有直接影响的.也就是说,程序的流程对运行结果 有直接的影响.所以,我们必须清楚每条语句的执行流程.而且,很多时候我们要通过控制语句的执行顺序来实 ...

  6. C语言 队列 链式结构 实现

    一个C语言链式结构实现的队列 mQueue (GCC编译). /** * @brief C语言实现的链式队列 * @author wid * @date 2013-10-31 * * @note 若代 ...

  7. C语言第二次作业-----顺序结构

    一:改错题 (1)输出指定信息: 将给定源代码输入编译器: 执行编译命令,发现编译器报错,错误信息如下: 经检查,发现源程序将"stdio.h"误拼为"stido.h&q ...

  8. C语言程序设计第二次作业--顺序结构

    C语言程序设计第二次作业--顺序结构 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 #include <stido ...

  9. C语言第二次作业——顺序结构

    一.改错题 1.输出带框文字:在屏幕上输出以下3行信息. (1)源程序 对程序进行编译,发现错误信息1 错误原因:stdio拼写错误 改正方法:将stdio正确拼写 对程序进行编译,发现错误信息2 错 ...

随机推荐

  1. windows命令行(Command Prompt / Console)字体设置

    1.运行 regedit 打开注册表编辑器,打开注册表定位至[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Conso ...

  2. Java基础以及与C++的一些对比

    这两天回忆一些Java基础,感觉自己很多地方都不是很牢固,也花费在不少时间和不少流量在手机上查资料. 还是写下来这些东西以免再忘记. 同时还是要记住多动手,编程最重要的就是动手敲啊,有想法有疑问就要自 ...

  3. linq 对Sum()函数的支持

    首先看一段SQL语句: SELECT SUM(TASKAPPR) AS APPRCOUNT, SUM(TASKLOCKED) AS LOCKEDCOUNT, SUM(TASKCHECKED) AS C ...

  4. dubbo properties

    DUBBO配置项的优先级: java -D优先于 Spring配置,Spring配置优先于 properties文件的配置,这也符合一般项目的规则. 覆盖策略: JVM启动-D参数优先,这样可以使用户 ...

  5. 关于form验证的处理片断

    public virtual void SignIn(s_User user, bool createPersistentCookie) { var now = DateTime.UtcNow.ToL ...

  6. POJ 1696 - Space Ant 凸包的变形

    Technorati Tags: POJ,计算几何,凸包 初学计算几何,引入polygon后的第一个挑战--凸包 此题可用凸包算法做,只要把压入凸包的点从原集合中排除即可,最终形成图形为螺旋线. 关于 ...

  7. dojo 加载Json数据

    1.今天研究了dojo datagrid加载WebService后台传上来的数据.研究来研究去发现他不是很难.用谷歌多调试一下就好了. 2.看很多例子,这个例子能够更好的帮我解决问题:https:// ...

  8. Android广播错误.MainActivity$MyReceiver; no empty constructor

    广播的定义,如果是内部类,必须为静态类. 下面总结一下作为内部类的广播接收者在注册的时候需要注意的地方:   1.清单文件注册广播接收者时,广播接收者的名字格式需要注意.因为是内部类,所以需要在内部类 ...

  9. Tableview的更新和删除某一行

    .tableView的刷新 > 数据刷新的总体步骤 * 修改模型数据 * 刷新表格(刷新界面) > 刷新表格(刷新界面)的方法 * 全局刷新(每一行都会重新刷新) - (void)relo ...

  10. Oracle列操作(增加列,修改列,删除列)

    Oracle列操作 增加一列: alter table emp4 add test varchar2(10); 修改一列: alter table emp4 modify test varchar2( ...