数据结构——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];
    }
}
相关推荐
想要成为糕糕手1 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
tyung3 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
Chen_harmony4 小时前
一、数据结构概念和复杂度计算
数据结构
小欣加油4 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
fie88896 小时前
LBP + HOG 特征检测与识别 MATLAB 实现
数据结构·算法·matlab
退休倒计时7 小时前
【每日一题】LeetCode 15. 三数之和 TypeScript
数据结构·算法·leetcode·typescript
AbandonForce8 小时前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
炸薯条!8 小时前
二叉树的链式表示(2)
java·数据结构·算法
YHHLAI8 小时前
JavaScript 数据结构精讲:数组底层与实战避坑
开发语言·javascript·数据结构
Coder-magician9 小时前
《代码随想录》刷题打卡day12:二叉树part02
数据结构·c++·算法