数据结构——02队列

数据结构------队列

队列(Queue)概念

队列(Queue):具有一定操作约束的线性表

插入和删除操作:只能在一端插入,而在另一端删除

数据插入:入队列(AddQ)

数据删除:出队列(DeleteQ)

先来先服务

先进先出:FIFO

队列的抽象数据类型描述

类型名称:队列(Queue)

数据对象集:一个有0个或多个元素的有穷线性表

操作集:长度为MaxSize的队列 Q ∈ \in ∈Queue,队列元素item ∈ \in ∈ ElementType

队列的顺序存储实现

队列的顺序存储结构通常由一个一维数组和一个记录队列头元素位置的变量 front 以及一个记录队列尾元素位置的变量 rear 组成。

c 复制代码
#define MaxSize <存储数据元素的最大个数>
struct QNode {
	ElementType Data[MaxSize];
	int rear; //指向队列尾部
	int front; //指向队列头部
};
typedef struct QNode *Queue;

当front和Rear都为 -1的时候,队列为空。

正常运行中的队列,front指向第一个元素的前一格,Rear指向队列最后一个元素。

出队列,front++

入队列,rear++

循环队列


Front == Rear时,队列为空

出队列,front++

入队列,rear++

(PtrQ->rear + 1)%MaxSize == PtrQ->front时,队列为满

循环队列入队列

c 复制代码
void AddQ(Queue PtrQ, ElementType item)
{
	if((PtrQ->rear+1)%MaxSize == PtrQ->front){
		printf("队列满");
		return;
	}
	PtrQ->rear = (PtrQ->rear+1)%MaxSize;
	PtrQ->Data[PtrQ->rear] = item;
}

循环队列出队列

c 复制代码
ElementType DeleteQ( Queue PtrQ )
{
    if ( PtrQ->front == PtrQ->rear ) {
        printf("队列空");
        return ERROR;
    }
    else {
        PtrQ->front = (PtrQ->front + 1) % MaxSize;
        return PtrQ->Data[PtrQ->front];
    }
}
相关推荐
星火开发设计14 分钟前
二叉树详解及C++实现
java·数据结构·c++·学习·二叉树·知识·期末考试
仍然.37 分钟前
JavaDataStructure---排序
数据结构·算法·排序算法
代码游侠1 小时前
应用——MQTT客户端开发
服务器·c语言·开发语言·数据结构·算法
独自破碎E2 小时前
链表中的节点每k个一组翻转
数据结构·链表
cookqq3 小时前
MySQL 5.7 大表删除部分数据:.ibd 文件会变小吗?磁盘会释放吗?
数据结构·数据库·mysql
D_FW3 小时前
数据结构第三章:栈、队列与数组
数据结构·算法
福楠3 小时前
模拟实现stack、queue、priority_queue
c语言·开发语言·数据结构·c++
budingxiaomoli4 小时前
优选算法--链表
数据结构·算法·链表
漫随流水4 小时前
leetcode算法(637.二叉树的层平均值)
数据结构·算法·leetcode·二叉树
漫随流水4 小时前
leetcode算法(102.二叉树的层序遍历)
数据结构·算法·leetcode·二叉树