队列的存储结构的实现(C/C++实现)

简介: 存档 1 #include "iostream.h" 2 #include "stdlib.h" 3 #define max 20 4 typedef char elemtype; 5 #include "queue.

存档

 1 #include "iostream.h"
 2 #include "stdlib.h"
 3 #define max 20
 4 typedef char elemtype;
 5 #include "queue.h"
 6 void main()
 7 {
 8     elemtype e;
 9     queue q;
10     cout<<"(1)初始化队列q"<<endl;
11     initqueue(q);
12     cout<<"(2)队列为"<<(queueempty(q)?"":"非空")<<endl;
13     cout<<"(3)依次输入字母序列,以'#'结束:"<<endl;
14     cin>>e;
15     while(e!='#')
16     {
17         enqueue(q,e);
18         cin>>e;
19     }
20     cout<<"(4)队列为"<<(queueempty(q)?"":"非空")<<endl;
21     e=dequeue(q);
22     cout<<"(5a)出队一个元素dequeue()为:"<<e<<endl;
23     if(dequeue1(q,e))
24         cout<<"(5b)出队一个元素dequeue1()为:"<<e<<endl;
25     cout<<"(6)队列q的元素个数:"<<queuelength(q)<<endl;
26     cout<<"(7)清空队列"<<endl;
27     clearqueue(q);
28     cout<<"(8)队列q的元素个数:"<<queuelength(q)<<endl;
29     cout<<"(9)字符abc依次入队列"<<endl;
30     enqueue(q,'a');
31     enqueue(q,'b');
32     enqueue(q,'c');
33     e=gethead(q);
34     cout<<"(10a)队头元素gethead()为:"<<e<<endl;
35     if (gethead1(q,e))
36         cout<<"(10b)队头元素gethead1()为:"<<e<<endl;
37     cout<<"(11)队列的元素个数:"<<queuelength(q)<<endl;
38     cout<<"(12)所有元素出队列:";
39     while(!queueempty(q))
40         cout<<dequeue(q)<<" ";
41     cout<<endl;
42     cout<<"(13)队列q的元素个数:"<<queuelength(q)<<endl;
43     cout<<"(14)释放队列"<<endl;
44     destoryqueue(q);
45 }
  1 typedef struct
  2 {
  3     elemtype *base;//动态分配存储空间
  4     int front;//头指针,若队列不空指向队列队头元素
  5     int rear;//尾指针,若队列不空指向队列队尾元素的下一个位置
  6 }queue;
  7 void initqueue(queue &q)
  8 {
  9     //初始化队列
 10     q.base=new elemtype[max];//分配存储空间
 11     if(!q.base)
 12     {
 13         cout<<"队列分配失败\n";
 14         exit(-2);
 15     }
 16     else
 17         q.front=q.rear=0;//初始状态,front和rear都为0
 18 }
 19 void clearqueue(queue &q)
 20 {
 21     //清空队列,但不销毁
 22     q.front=0;//清空函数,恢复到初始状态
 23     q.rear=0;
 24 }
 25 int queueempty(queue q)
 26 {
 27     //判断队列是否为空
 28     if(q.front==q.rear)//空队列,返回1,否则返回0
 29         return 1;
 30     else
 31         return 0;
 32 }
 33 int queuelength(queue q)
 34 {
 35     //求队列中元素个数
 36     return (q.rear-q.front+max)%max;//计算队列当前存储的元素数目
 37 }
 38 void enqueue(queue &q,elemtype e)
 39 {
 40     //入队列操作
 41     if((q.rear+1)%max==q.front)//队满的操作
 42     {
 43         cout<<"队满,无法插入新元素!"<<endl;
 44         exit(-2);
 45     }
 46     else
 47     {
 48         q.base[q.rear]=e;//元素e存在当前rear所指位置
 49         q.rear=(q.rear+1)%max;//rear指针后移
 50     }
 51 }
 52 elemtype dequeue(queue &q)
 53 {
 54     //出队列操作
 55     if(q.front==q.rear)//空队列不能出队
 56     {
 57         //队空
 58         cout<<"空队列,无法删除头元素!"<<endl;
 59         exit(-2);
 60     }
 61     else
 62     {
 63         elemtype e=q.base[q.front];//当前的队列头元素作为返回值
 64         q.front=(q.front+1)%max;//front指针后移
 65         return e;
 66     }
 67 }
 68 int dequeue1(queue &q,elemtype &e)
 69 {
 70     //出队列操作
 71     if(q.front==q.rear)//空队列不能出队
 72     {
 73         //队空
 74         cout<<"空队列,无法删除头元素!"<<endl;
 75         return 0;
 76     }
 77     else
 78     {
 79         e=q.base[q.front];//当前的队列头元素作为返回值
 80         q.front=(q.front+1)%max;//front指针后移
 81         return 1;
 82     }
 83 }
 84 elemtype gethead(queue q)
 85 {
 86     //读队头元素的值,但不删除
 87     if(q.front==q.rear)//空队列,无法读
 88     {
 89         //队空
 90         cout<<"空队列,无头元素"<<endl;
 91         exit(-2);
 92     }
 93     else 
 94         return q.base[q.front];//队列头元素的数组下标即front本身
 95 }
 96 void destoryqueue(queue &q)
 97 {
 98     //销毁队列
 99     delete q.base;//释放连续的存储空间
100     q.base=NULL;//基地址赋值为空
101     q.front=0;//头指针赋值为0
102     q.rear=0;//尾指针赋值为0
103 }
104 int gethead1(queue q,elemtype &e)
105 {
106     //读队头元素的值,但不删除
107     if(q.front==q.rear)//空队列,无法读
108     {
109         //队空
110         cout<<"空队列,无头元素"<<endl;
111         return 0;
112     }
113     else 
114         e=q.base[q.front];//队列头元素的数组下标即front本身
115     return 1;
116 }

运行结果如下:

 

目录
相关文章
|
3月前
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
223 77
|
2月前
|
存储 算法 C++
【c++丨STL】priority_queue(优先级队列)的使用与模拟实现
本文介绍了STL中的容器适配器`priority_queue`(优先级队列)。`priority_queue`根据严格的弱排序标准设计,确保其第一个元素始终是最大元素。它底层使用堆结构实现,支持大堆和小堆,默认为大堆。常用操作包括构造函数、`empty`、`size`、`top`、`push`、`pop`和`swap`等。我们还模拟实现了`priority_queue`,通过仿函数控制堆的类型,并调用封装容器的接口实现功能。最后,感谢大家的支持与关注。
114 1
|
3月前
|
存储 C++ 索引
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
【数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】初始化队列、销毁队列、判断队列是否为空、进队列、出队列等。本关任务:编写一个程序实现环形队列的基本运算。(6)出队列序列:yzopq2*(5)依次进队列元素:opq2*(6)出队列序列:bcdef。(2)依次进队列元素:abc。(5)依次进队列元素:def。(2)依次进队列元素:xyz。开始你的任务吧,祝你成功!(4)出队一个元素a。(4)出队一个元素x。
136 13
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
|
3月前
|
存储 算法 C++
【C++数据结构——图】图的邻接矩阵和邻接表的存储(头歌实践教学平台习题)【合集】
本任务要求编写程序实现图的邻接矩阵和邻接表的存储。需掌握带权有向图、图的邻接矩阵及邻接表的概念。邻接矩阵用于表示顶点间的连接关系,邻接表则通过链表结构存储图信息。测试输入为图的顶点数、边数及邻接矩阵,预期输出为Prim算法求解结果。通关代码提供了完整的C++实现,包括输入、构建和打印邻接矩阵与邻接表的功能。
87 10
|
3月前
|
存储 C语言 C++
【C++数据结构——栈与队列】链栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现链栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储整数,最大
77 9
|
3月前
|
C++
【C++数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】
【数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】(1)遇到左括号:进栈Push()(2)遇到右括号:若栈顶元素为左括号,则出栈Pop();否则返回false。(3)当遍历表达式结束,且栈为空时,则返回true,否则返回false。本关任务:编写一个程序利用栈判断左、右圆括号是否配对。为了完成本关任务,你需要掌握:栈对括号的处理。(1)遇到左括号:进栈Push()开始你的任务吧,祝你成功!测试输入:(()))
117 7
|
5月前
|
缓存 安全 C++
C++无锁队列:解锁多线程编程新境界
【10月更文挑战第27天】
317 7
|
5月前
|
消息中间件 存储 安全
|
5月前
|
存储 设计模式 C++
【C++】优先级队列(容器适配器)
本文介绍了C++ STL中的线性容器及其适配器,包括栈、队列和优先队列的设计与实现。详细解析了`deque`的特点和存储结构,以及如何利用`deque`实现栈、队列和优先队列。通过自定义命名空间和类模板,展示了如何模拟实现这些容器适配器,重点讲解了优先队列的内部机制,如堆的构建与维护方法。
93 0
|
7月前
|
C++
【C++基础】程序流程结构详解
这篇文章详细介绍了C++中程序流程的三种基本结构:顺序结构、选择结构和循环结构,包括if语句、三目运算符、switch语句、while循环、do…while循环、for循环以及跳转语句break、continue和goto的使用和示例。
133 2