数据结构——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];
    }
}
相关推荐
谙弆悕博士2 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
smj2302_7968265211 小时前
解决leetcode第3934题最短唯一子数组
数据结构·python·算法·leetcode
iiiiyu11 小时前
面向对象和集合编程题
java·开发语言·前端·数据结构·算法·编程语言
变量未定义~11 小时前
最长回文子串
数据结构·算法
代码中介商11 小时前
AVL树:自平衡二叉搜索树的奥秘
数据结构
玛卡巴卡ldf12 小时前
【LeetCode 手撕算法】(多维动态规划)不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离
java·数据结构·算法·leetcode·动态规划·力扣
被AI抢饭碗的人12 小时前
算法:数据结构
数据结构·算法
淞綰13 小时前
c语言的练习-字符串的练习-寻找最长连续字符以及出现次数
c语言·数据结构·学习·算法·c语言的练习
qq_2965532713 小时前
[特殊字符] 搜索插入位置:从O(n)到O(log n)的优雅进化
数据结构·算法·面试·分类·柔性数组
凯瑟琳.奥古斯特13 小时前
力扣3654:二维矩阵连续空位统计
数据结构·数据库·算法·职场和发展