数据结构——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];
    }
}
相关推荐
仰泳的熊猫5 小时前
1176 The Closest Fibonacci Number
数据结构·c++·算法·pat考试
一条大祥脚5 小时前
Cuda Rudece算子实现(附4090/h100测试)
java·数据结构·算法
2401_841495646 小时前
【LeetCode刷题】跳跃游戏
数据结构·python·算法·leetcode·游戏·贪心算法·数组
_w_z_j_7 小时前
全排列问题(包含重复数字与不可包含重复数字)
数据结构·算法·leetcode
@小码农7 小时前
LMCC大模型认证 青少年组 第一轮模拟样题
数据结构·人工智能·算法·蓝桥杯
CoderYanger7 小时前
A.每日一题——3606. 优惠券校验器
java·开发语言·数据结构·算法·leetcode
coderxiaohan7 小时前
【C++】哈希表实现
数据结构·哈希算法·散列表
CoderYanger7 小时前
D.二分查找-基础——744. 寻找比目标字母大的最小字母
java·开发语言·数据结构·算法·leetcode·职场和发展
元亓亓亓7 小时前
LeetCode热题100--347. 前 K 个高频元素--中等
数据结构·算法·leetcode