2015年大二上-数据结构-队列(1)- 顺序环形队列算法库

来源:互联网 发布:美容院用的软件 编辑:程序博客网 时间:2024/06/05 03:52

顺序环形队列算法库采用程序的多文件组织形式,包括两个文件:

1.头文件:SqQueue.h,包含定义顺序环形队列数据结构的代码、宏定义、要实现算法的函数的声明;

/* *Copyright (c) 2014,烟台大学计算机学院 *All rights reserved. *文件名称:Annpion.cpp *作者:王耀鹏 *完成日期:2015年11月15日 *版本号:v1.0 * *问题描述:头文件。 *输入描述:无。 *输出描述:无。 */  #ifndef SQQUEUE_H_INCLUDED#define SQQUEUE_H_INCLUDED#define MaxSize 5typedef char ElemType;typedef struct{    ElemType data[MaxSize];    int rear,front;}SqQueue;void InitQueue(SqQueue *&q);  //初始化顺序环形队列void DestroyQueue(SqQueue *&q); //销毁顺序环形队列bool QueueEmpty(SqQueue *q);  //判断顺序环形队列是否为空int QueueLength(SqQueue *q);   //返回队列中元素个数,也称队列长度bool enQueue(SqQueue *&q,ElemType e);   //进队bool deQueue(SqQueue *&q,ElemType &e);  //出队#endif // SQQUEUE_H_INCLUDED

2.源文件:SqQueue.cpp,包含实现各种算法的函数的定义

/* *Copyright (c) 2014,烟台大学计算机学院 *All rights reserved. *文件名称:Annpion.cpp *作者:王耀鹏 *完成日期:2015年11月15日 *版本号:v1.0 * *问题描述:源文件。 *输入描述:无。 *输出描述:无。 */  #include <stdio.h>#include <malloc.h>#include "SqQueue.h"void InitQueue(SqQueue *&q){    q=(SqQueue *)malloc(sizeof(SqQueue));    q->rear=q->front=-1;}void DestroyQueue(SqQueue *&q){    free(q);}bool QueueEmpty(SqQueue *q){    return (q->rear==q->front);}int QueueLength(SqQueue *q){    return (q->rear-q->front+MaxSize)%MaxSize;}bool enQueue(SqQueue *&q,ElemType e){    if((q->rear+1)%MaxSize==q->front)        return false;    q->rear=(q->rear+1)%MaxSize;    q->data[q->rear]=e;    return true;}bool deQueue(SqQueue *&q,ElemType &e){    if(QueueEmpty(q))        return false;    q->front=(q->front+1)%MaxSize;    e=q->data[q->front];    return true;}

3.在同一项目(project)中建立一个源文件(如main.cpp),编制main函数,完成相关的测试工作。

/* *Copyright (c) 2014,烟台大学计算机学院 *All rights reserved. *文件名称:Annpion.cpp *作者:王耀鹏 *完成日期:2015年11月15日 *版本号:v1.0 * *问题描述:顺序环形队列算法库采用程序的多文件组织形式。 *输入描述:无。 *输出描述:输出操作时的动态。 */  #include <stdio.h>#include "sqqueue.h"int main(){    ElemType e;    SqQueue *q;    printf("(1)初始化队列q\n");    InitQueue(q);    printf("(2)依次进队列元素a,b,c\n");    if (enQueue(q,'a')==0) printf("队满,不能进队\n");    if (enQueue(q,'b')==0) printf("队满,不能进队\n");    if (enQueue(q,'c')==0) printf("队满,不能进队\n");    printf("(3)队列为%s\n",(QueueEmpty(q)?"空":"非空"));    if (deQueue(q,e)==0)        printf("队空,不能出队\n");    else        printf("(4)出队一个元素%c\n",e);    printf("(5)队列q的元素个数:%d\n",QueueLength(q));    printf("(6)依次进队列元素d,e,f\n");    if (enQueue(q,'d')==0) printf("队满,不能进队\n");    if (enQueue(q,'e')==0) printf("队满,不能进队\n");    if (enQueue(q,'f')==0) printf("队满,不能进队\n");    printf("(7)队列q的元素个数:%d\n",QueueLength(q));    printf("(8)出队列序列:");    while (!QueueEmpty(q))    {        deQueue(q,e);        printf("%c ",e);    }    printf("\n");    printf("(9)释放队列\n");    DestroyQueue(q);    return 0;}

运行结果:


0 0
原创粉丝点击