队列结构

概念:

队列(queue):和栈相似,也是一种特殊的线性表。和栈不同的是,队列只允许在表的一端进行插入操作,而在另一端进行删除操作。一般来说,进行插入操作的一端称为队尾,进行删除操作的一端称为队头。队列中没有元素时成为空队列

队列结构采取“先进先出”的原则处理结点数据。

分类:

以存储结构划分,分为两类:

顺序队列结构

使用一组地址连续的内存单元依次保存在队列中的数据。在程序中,可以定义一个指定大小的结构数组来作为队列。

链式队列结构

使用链表形式保存队列中各元素的值

队列的基本操作:

  • 入队列:将一个元素添加到队尾(相当于到队列最后等候)

  • 出队列:将队头的元素取出,同时删除该元素,使后一个元素成为队头。

队列的程序设计

准备数据:

准备在队列操作中要用到的变量以及数据结构

#define QUEUELEN 15
typedef struct
{ char name[10];
int age;
}DATA;

typedef struct
{
DATA data[QUEUELEN]; //队列数组
int head;
int tail;
}SQType;

这里定义了队列结构的最大长度QUEUELEN,队列结构数据元素的类型DATA以及队列结构的数据结构 SQType 。在数据结构 SQType 中,data 为数据元素,head 为队头的序号,tail 为队尾的序号。当 head=0 时表示队列为空,当 tail=QUEUELEN 时表示队列为满。

初始化队列结构:

创建一个空的顺序队列。步骤如下:

  1. 按符号常量 QUEUELEN 指定的大小申请一块内存空间,用来保存队列中的数据。

  2. 设置 head=0 和 tail=0 ,表示是一个空栈。

初始化顺序队列的示例代码如下:

SQType* SRTpyeInit()
{
SQType* q;

if (q = (SQType*)malloc(sizeof(SQType))) //申请内存
{
q->head = 0; //设置队头
q->tail = 0; //设置队尾
return q;
}
else
{
return NULL; //返回空
}
}

这里采用 malloc() 申请内存,申请成功后设置队头和队尾,返回申请内存的首地址。如果申请内存失败,将返回 NULL

判断队列:

判断空队列

int SQTypeIsEmpty(SQType* q)
{
int temp;
temp = q->head == q->tail;
return temp;
}

在这里,输入一个参数 q 为一个指向操作的队列的指针。程序中,根据队列 head 是否等于 tail ,判断队列是否为空。

判断满队列

int SQTypeIsFull(SQType* q)
{
int temp;
temp = q->tail == QUEUELEN;
return temp;
}

在这里,输入一个参数 q 为一个指向操作的队列的指针。程序中,根据队列 tail 是否等于符号常量QUEUELEN ,判断队列是否为满。

清空队列:

void SQTypeClear(SQType* q)
{
q->head = 0; //设置队头
q->tail = 0; //设置队尾
}

在这里,输入一个参数 q 为一个指向操作的队列的指针。程序中,将队列顶指针 head和 tail 设置为 0,表示执行清空队列操作。

释放空间:

释放队列结构所占用的内存单元。由前面可知,在初始化队列结构时,使用了 malloc() 函数分配内存空间。虽然可以使用清空队列的操作,但是清空队列操作并没有释放内存空间,所以需要用 free() 释放所分配的内存。

void SQTypeFree(SQType* q)
{
if (q != NULL)
free(q);
}

在这里,输入一个参数 q 为一个指向操作的队列的指针。程序中,直接调用 free() 释放所分配的内存。多用于程序结束时。

出入队列:

入队列

将数据元素保存到队列结构。具体步骤如下:

  1. 首先判断队列顶 tail,如果 tail 等于QUEUELEN,则表示溢出,进行出错处理。

  2. 设置 tail=tail+1 (队列顶指针+1,指向入队列地址)

  3. 将队列元素保存到 tail 指向的位置。

代码示例:

int InSQType(SQType* q,DATA data)
{
if (q->tail == QUEUELEN)
{
printf("队列已满操作失败!\n");
}
else
{
q->data[q->tail++] = data; //将元素入队列
return 1;
}
}

出队列

从队列顶弹出一个数据元素。具体步骤如下:

  1. 判断队列 head,如果 head 等于 tail,则表示为空指针,进行出错处理。

  2. 从队列首部取出队头元素(返回队头元素的指针)

  3. 设修改队头 head 的序号,使其指向后一个元素。

代码示例:

DATA* OutSQType(SQType* q)
{
if (q->tail == q->tail)
{
printf("队列已空,操作失败!\n");
exit(0);
}
else
{
return &(q->data[q->head++]);
}
}

读取结点数据

与出队列不同,读结点的操作只是显示内容,而出队列会使该数据不再存在。

代码示例:

DATA* OutSQType(SQType* q)
{
if (SQTypeIsEmpty(q))
{
printf("空队列!\n");
return NULL;
}
else
{
return &(q->data[q->head]);
}
}

在这里,输入一个参数 q 为一个指向操作的队列的指针。程序返回值同样是一个(指向 DATA 类型的指针数据的)指针。


制作:BDT20040

[C++STL] 队列 queue 的入门的更多相关文章

  1. C++ 标准模板库STL 队列 queue 使用方法与应用介绍

    C++ 标准模板库STL 队列 queue 使用方法与应用介绍 queue queue模板类的定义在<queue>头文件中. 与stack模板类很相似,queue模板类也需要两个模板参数, ...

  2. c++ STL:队列queue、优先队列priority queue 的使用

    说明:本文全文转载而来,原文链接:http://www.cppblog.com/wanghaiguang/archive/2012/06/05/177644.html C++ Queues(队列) C ...

  3. STL中的单向队列queue

    转载自:http://blog.csdn.net/morewindows/article/details/6950917 stl中的queue指单向队列,使用时,包含头文件<queue>. ...

  4. Windows Azure Service Bus (2) 队列(Queue)入门

    <Windows Azure Platform 系列文章目录> Service Bus 队列(Queue) Service Bus的Queue非常适合分布式应用.当使用Service Bu ...

  5. STL学习笔记6 -- 栈stack 、队列queue 和优先级priority_queue 三者比较

    栈stack  .队列queue  和优先级priority_queue 三者比较 默认下stack 和queue 基于deque 容器实现,priority_queue 则基于vector 容器实现 ...

  6. STL中队列queue的用法

    头文件:#include <queue> 建立一个队列queue < 类型 > q 加入一个新的元素q.push(a) 询问队首元素q.front() 弹出队首元素q.pop( ...

  7. Windows Azure Service Bus (3) 队列(Queue) 使用VS2013开发Service Bus Queue

    <Windows Azure Platform 系列文章目录> 在之前的Azure Service Bus中,我们已经介绍了Service Bus 队列(Queue)的基本概念. 在本章中 ...

  8. Gengxin讲STL系列——Queue和Stack

    第三篇. 感觉队列和栈是必须的……所以决定加上这两个…… 我发现我已经买域名买上隐了……今天又买了个.top……真是智障…… Queue(队列FIFO)和Statk(栈LIFO). 那么为什么要这两个 ...

  9. STL之Queue(Q)

    STL的Queue(数据结构中的队列): 特点:FIFO 先进先出: 自适应容器(即容器适配器)   栈适配器STL queue  STL中实现的Queue: 用list来实现queue: queue ...

随机推荐

  1. Codepen 每日精选(2018-3-24)

    按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以打开原始页面. 纯 css 画的抽象小鸟https://codepen.io/gregoryb/f... 纯 css 制作 ...

  2. Android CheckBox的监听事件

    1.在xml文件中定义CheckBox,一定要定义id <CheckBox android:id="@+id/beijing" android:layout_width=&q ...

  3. 小程序wx.previewImage查看图片再次点击返回时重新加载页面问题

    wx.previewImage预览图片这个过程到底发生了什么? 首先我们点击图片预览,附上查看图片代码: <image class="headImg" data-src=&q ...

  4. 如何在云服务器上安装vim(bash: vim :command not found)

    1.apt-get update 2.apt-get install vim vim文件即可成功!

  5. Spring原始注解开发-02

    使用@Repository.@Service.@Controller注解配置,使其更加清晰属于哪一层,因为我是模拟的web层,所有没有使用@Controller注解,后面结合web开发会使用到 1.创 ...

  6. intel 82599网卡(ixgbe系列)术语表

    Intel® 82599 10 GbE Controller Datasheet 15.0 Glossary and Acronyms 术语表 缩写 英文解释 中文解释 1 KB A value of ...

  7. 用户USER_HZ与内核HZ的值

    HZ和Jiffies系统定时器timer能够以可编程的方式设定频率,来中断cpu处理器.此频率即hz,为每秒的定时器节拍(tick)数, 对应着内核变量HZ.选择合适的HZ值需要权衡. tick为两个 ...

  8. 一些有用的工具,iftop,iotop,htop,glances

    一些有用的工具: yum install glances -y资源监控工具GLANCESglances 可以为 Unix 和 Linux 性能专家提供监视和分析性能数据的功能,其中包括:CPU 使用率 ...

  9. swagger不再是第一选择了

    ​ 一.前言 工欲善其事,必先利其器 最近对 API 接口协作的软件研究了好久,市面上的软件都下载用了一轮,下面给大家介绍其中的最强「神器」 Apifox. Apifox 官网:apifox.cn 在 ...

  10. Java进阶 JVM 内存与垃圾回收篇(一)

    JVM 1. 引言 1.1 什么是JVM? 定义 Java Vritual Machine - java 程序的运行环境(Java二进制字节码的运行环境) 好处 一次编译 ,到处运行 自动内存管理,垃 ...