【图文并茂】c++介绍之队列

1.1队列的定义

队列(queue)简称队,它也是一种操作受限的线性表,其限制为仅允许在表的一端进行插入操作,而在表的另一端进行删除操作

一些基础概念:

  • 队尾(rear) :进行插入的一端
  • 队首(front):进行删除的一端
  • 入队(enqueue):插入新元素
  • 出队(dequeue):删除新元素

队列是一种先进先出表(FIFO),而前面介绍过的栈是一种先进后出表。

(一个队列)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传


1.2队列抽象数据类型

如图:

在这里插入图片描述


1.3队列的顺序存储结构及其基本运算

队列中数据元素的逻辑结构呈线性关系,所以队列可以像线性表一样采用顺序存储结构进行存储,即分配一块连续的存储空间来存放队列的元素,并用两个指针来反映队列中元素变化

顺序队:采用顺序存储结构的队列

(1)声明

typedef int ElemType;
#define MaxSiaze 50
typedef struct
{ElemType data[MaxSiaze];int front, rear;	//队头与队尾指针
}SqQueue;

图示:

在这里插入图片描述
Pe-1694079903125)

(2)初始化队列

//初始化队列
void InitQueue(SqQueue*& q)
{q = (SqQueue*)malloc(sizeof(SqQueue));q->front = q->rear = -1;
}

(3)销毁队列

//销毁队列
void DestroyQueue(SqQueue*& q)
{free(q);
}

(4)判断队列是否为空

//判断队列是否为空
bool QueueEmpty(SqQueue*&q)
{return(q->front == q->rear);
}

(5)入队

bool enQueue(SqQueue*& q, ElemType e)
{if (q->rear == MaxSiaze - 1)	//队满上溢出return false;q->rear++;q->data[q->rear] = e;return true;
}

(6)出队

bool deQueue(SqQueue*& q, ElemType& e)
{if (q->front == q->rear)//队空下溢出return false;q->front++;e = q->data[q->front];return true;
}

完整代码:

#include<iostream>
using namespace std;
typedef int ElemType;
#define MaxSiaze 50
typedef struct
{ElemType data[MaxSiaze];int front, rear;	//队头与队尾指针
}SqQueue;
//初始化队列
void InitQueue(SqQueue*& q)
{q = (SqQueue*)malloc(sizeof(SqQueue));q->front = q->rear = -1;
}
//销毁队列
void DestroyQueue(SqQueue*& q)
{free(q);
}
//判断队列是否为空
bool QueueEmpty(SqQueue*&q)
{return(q->front == q->rear);
}
bool enQueue(SqQueue*& q, ElemType e)
{if (q->rear == MaxSiaze - 1)	//队满上溢出return false;q->rear++;q->data[q->rear] = e;return true;
}
bool deQueue(SqQueue*& q, ElemType& e)
{if (q->front == q->rear)//队空下溢出return false;q->front++;e = q->data[q->front];return true;
}
int main() {return 0;
}

1.4队列的链式存储结构及其基本运算

链队:采用链式存储结构的队列

对于单链表实现的链队,在这种链队中只允许在单链表的表头进行删除操作和在表尾进行插入操作

链队的基本知识:

  • 队空的条件 q -->rear == NULL(也可以是q -->front == NULL)
  • 队满的条件:不考虑
  • 元素e的进队操作:新建一个结点存放元素e(由p指向它,将结点p插入作为尾结点)
  • 出队操作:取出队首结点的data值并将其删除

(1)声明

typedef int ElemType;
typedef struct qnode
{ElemType data;	//存放元素struct qnode* next;//下一个结点指针
}DataNode;
typedef struct
{DataNode* front; //指向队首结点DataNode* rear; //指向队首结点
}LinkQuNode;

(2)销毁队列

//销毁
void DestroyQueue(LinkQueue *&q)
{DataNode * pre = q->front,*p;	//pre指向队首结点 if(pre!=NULL){p = pre->next;				//p指向结点pre的后继结点 while(p!=NULL)				//p不空循环 {free(pre);				//释放pre结点 pre = p;				//同步后移 p = p->next;}free(pre);}free(q);
} 

(3)判断队列是否为空

bool QueueEmpty(LinkQueue *q)
{return (q-->rear == NULL)
}

(4)进队列

//进队列
void enQueue(LinkQuNode*& q,ElemType e)
{DataNode* p;p = (DataNode*)malloc(sizeof(DataNode));p->data = e;p->next = NULL;if (q->rear == NULL)//若链队为空,则新结点既是队首结点又是队尾结点q->front = q->rear = p;else{q->rear->next = p;	//将结点p链接到队尾,并将rear指向它q->rear = p;}
}

(5)出队列

//出队列
bool deQueue(LinkQuNode*& q, ElemType e)
{DataNode* t;if (q->rear == NULL)	//原来队列已经为空return false;t = q->front;			//指向首结点if (q->front == q->rear)	//原来队列中只有一个数据结点q->front = q->rear = NULL;elseq->front = q->front->next;e = t->data;free(t);return true;
}

完整代码:

#include<iostream>
using namespace std;
typedef int ElemType;
typedef struct qnode
{ElemType data;	//存放元素struct qnode* next;//下一个结点指针
}DataNode;
typedef struct
{DataNode* front; //指向队首结点DataNode* rear; //指向队首结点
}LinkQuNode;//初始化
void InitQueue(LinkQuNode*& q)
{q = (LinkQuNode*)malloc(sizeof(LinkQuNode));q->front = q->rear = NULL;
}
//销毁
void DestroyQueue(LinkQueue *&q)
{DataNode * pre = q->front,*p;	//pre指向队首结点 if(pre!=NULL){p = pre->next;				//p指向结点pre的后继结点 while(p!=NULL)				//p不空循环 {free(pre);				//释放pre结点 pre = p;				//同步后移 p = p->next;}free(pre);}free(q);
} 
//进队列
void enQueue(LinkQuNode*& q,ElemType e)
{DataNode* p;p = (DataNode*)malloc(sizeof(DataNode));p->data = e;p->next = NULL;if (q->rear == NULL)//若链队为空,则新结点既是队首结点又是队尾结点q->front = q->rear = p;else{q->rear->next = p;	//将结点p链接到队尾,并将rear指向它q->rear = p;}
}
//出队列
bool deQueue(LinkQuNode*& q, ElemType e)
{DataNode* t;if (q->rear == NULL)	//原来队列已经为空return false;t = q->front;			//指向首结点if (q->front == q->rear)	//原来队列中只有一个数据结点q->front = q->rear = NULL;elseq->front = q->front->next;e = t->data;free(t);return true;
}
int main()
{return 0;
}

当然了,队列的形式多种多样,比如双端队列,循环队列等等。希望本文对你有所帮助
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/75754.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MFC新建内部消息

提示&#xff1a;记录一下MFC新建内部消息的成功过程 文章目录 前言一、第一阶段二、第二阶段三、第三阶段总结 前言 先说一下基本情况&#xff0c;因为要在mapview上增加一个显示加载时间的功能。然后发现是要等加载完再显示时间&#xff0c;显示在主窗口。所以就是在子线程中…

开开心心带你学习MySQL数据库之节尾篇

Java的JDBC编程 各种数据库,MySQL, Oracle, SQL Server在开发的时候,就会提供一组编程接口(API) API ~~ Application Programming Interface ~~ 应用程序编程接口 计算机领域里面的一个非常常见的概念, 给你个软件,你能对他干啥(从代码层次上的) 基于它提供的这些功能,就可以写…

AJAX学习笔记5同步与异步理解

AJAX学习笔记4解决乱码问题_biubiubiu0706的博客-CSDN博客 示例 前端代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>演示AJAX同步和异步</title> </head> <body> <script…

深眸科技自研轻辙视觉引擎,以AI机器视觉赋能杆号牌识别与分拣

电线杆号牌作为电力行业标识的一种&#xff0c;相当于电线杆的“身份证”&#xff0c;担负着宣传电力知识、安全警示的作用&#xff0c;用于户外使用标记输电线路电压等级、线路名称、杆塔编号等&#xff0c;能够清晰地记录电力线路杆的信息&#xff0c;并为电力线路的更改以及…

ChatGPT是如何辅助高效撰写论文及使用ChatGPT注意事项

ChatGPT发布近1年&#xff0c;各大高校对它的态度也发生了极大转变&#xff0c;今年3月发布ChatGPT禁令的牛剑等世界顶级名校也在近期解除了ChatGPT禁令&#xff0c;发布了生成式人工智能使用指南。 ChatGPT一定程度上可以解放科研人员的劳动力&#xff0c;与其直接禁止不如教…

Docker笔记-概念安装简单使用

概念 docker通用词汇。 镜像&#xff1a;Build&#xff0c;创建一个镜像。 仓库&#xff1a;Ship&#xff0c;从仓库和主机上运输镜像。 容器&#xff1a;Run&#xff0c;运行的镜像就是一个容器。 安装 Windows上安装 Docker对win10有原生的支持&#xff0c;win10下的是…

thinkphp6-简简单单地开发接口

目录 1.前言TP6简介 2.项目目录3.运行项目运行命令访问规则 4.model db使用db连接配置model编写及调用调用接口 5.返回json格式 1.前言 基于上篇文章环境搭建后&#xff0c;便开始简单学习上手开发接口…记录重要的过程&#xff01; Windows-试用phpthink发现原来可这样快速搭…

IDEA在创建包时如何把包分开实现自动分层

IDEA在创建包时如何把包分开实现自动分层 文章目录 IDEA在创建包时如何把包分开实现自动分层一、为什么要把包分开二、建包时如何把包自动分开三、如何编写配置文件路径&#xff1f; 一、为什么要把包分开 一开始的时候&#xff0c;我也一直以为包连在一起和分开没什么区别&am…

linux内核模块编译方法之模块编程详解

文章目录 一、模块传参二、模块依赖三、内核空间和用户空间四、执行流五、模块编程与应用编程的比较六、内核接口头文件查询总结 本期和大家主要分享的是驱动开发内核编译过程中对于模块是如何设计的&#xff0c;进行了详细的分享&#xff0c;从模块传参、模块依赖一直到内核空…

Linux dup dup2函数

/*#include <unistd.h>int dup2(int oldfd, int newfd);作用&#xff1a;重定向文件描述符oldfd 指向 a.txt, newfd 指向b.txt,调用函数之后&#xff0c;newfd和b.txt close&#xff0c;newfd指向a.txtoldfd必须是一个有效的文件描述符 */ #include <unistd.h> #i…

Python怎么实现更高效的数据结构和算法? - 易智编译EaseEditing

要实现更高效的数据结构和算法&#xff0c;你可以考虑以下几个方面的优化&#xff1a; 选择合适的数据结构&#xff1a; 选择最适合你问题的数据结构至关重要。例如&#xff0c;如果需要频繁插入和删除操作&#xff0c;可能链表比数组更合适。如果需要高效查找操作&#xff0…

基于java SpringBoot和Vue uniapp的影楼摄影预约小程序

摘要 今天信息技术的发展很快&#xff0c;其足迹在我们的生活中随处可见。它影响着我们的衣食住行等各种需求。影响也在逐渐增加&#xff0c;逐渐渗透到各行各业&#xff0c;在这种背景下&#xff0c;经过实地考察后&#xff0c;为了让婚纱照管理更加高效方便&#xff0c;我决定…

Mac系统 AndroidStudio Missing essential plugin:org.jetbrains.android报错

打开Android Studio,提示 Missing essential plugin:org.jetbrains.android错误&#xff0c;产生的原因是Kotlin被禁用。 解决的方法是删除disabled_plugins.txt&#xff0c;Mac OS对应的路径为&#xff1a; /Users/xzh/Library/Application Support/Google/AndroidStudio202…

C高级 DAY4

一、分支语句 case ...in语句 shell中的switch语句 case $变量名 in常量1)语句;; ------->类似于C中break的作用&#xff0c;;;除了最后一条分之外&#xff0c;都不能省略常量2)语句;; 常量n)语句;;*) ------->类似于C中default&#xff0c;但…

【码银送书第六期】《ChatGPT原理与实战:大型语言模型的算法、技术和私有化》

写在前面 2022年11月30日&#xff0c;ChatGPT模型问世后&#xff0c;立刻在全球范围内掀起了轩然大波。无论AI从业者还是非从业者&#xff0c;都在热议ChatGPT极具冲击力的交互体验和惊人的生成内容。这使得广大群众重新认识到人工智能的潜力和价值。对于AI从业者来说&#xf…

【多线程】volatile 关键字

volatile 关键字 1. 保证内存可见性2. 禁止指令重排序3. 不保证原子性 1. 保证内存可见性 内存可见性问题: 一个线程针对一个变量进行读取操作&#xff0c;另一个线程针对这个变量进行修改操作&#xff0c; 此时读到的值&#xff0c;不一定是修改后的值&#xff0c;即这个读线…

【动态规划】01背包问题

文章目录 动态规划&#xff08;背包问题&#xff09;1. 01背包2. 分割等和子集3. 目标和4. 最后一块石头的重量 || 动态规划&#xff08;背包问题&#xff09; 1. 01背包 题目链接 状态表示 dp[i][j] 表示从前i个物品当中挑选&#xff0c;总体积不超过j,所有选法当中能挑选出…

UDP协议

目录 一、UDP协议端格式 二、UDP的特点 一、UDP协议端格式 16位UDP长度&#xff0c;表示整个数据报&#xff08;UDP首部UDP数据&#xff09;的最大长度&#xff1b;如果校验和出错&#xff0c;就会直接丢弃 二、UDP的特点 UDP相对于TCP来说是相对简单的&#xff0c;但是在传输…

Redis:实现全局唯一id

&#xff08;笔记总结自《黑马点评》项目&#xff09; 一、全局ID生成器 全局ID生成器&#xff0c;是一种在分布式系统下用来生成全局唯一ID的工具&#xff0c;一般要满足下列特性&#xff1a; 二、原理 为了增加ID的安全性&#xff0c;我们可以不直接使用Redis自增的数值&…

测试----计算机网络

文章目录 计算机网络的历史OSI/RM 协议TCP/IP协议IP地址 计算机网络的历史 50-60年代 内部通讯功能&#xff08;连接的是同一台主机&#xff0c;只能主机和终端之间通信&#xff0c;终端和终端之间的通讯只能依靠主机来传输&#xff09;60-70年代 主机和主机之间能通讯70年代-…