DS-3 循环队列判断队满

一、循环队列判断队满有什么问题?

循环队列用数组实现,会遇到一个问题:

  • 队空front == rear

  • 队满front == rear

两个状态完全一样,无法区分。

二、三种解决办法

方法1:牺牲一个元素空间(最常用)

  • 思路:刻意少用一个数组位置,不存数据,专门用来区分空满

  • 队空:front == rear

  • 队满:(rear + 1) % MAXSIZE == front

  • 最大容量:MAXSIZE - 1

  • 优点:简单直观,无需额外变量

  • 缺点:浪费 1 个单元空间

cpp 复制代码
#include <stdio.h>
#define MAXSIZE 5  // 数组长度5,牺牲1个,最多存4个元素

// 循环队列结构
typedef struct {
    int data[MAXSIZE];
    int front;  // 队头指针
    int rear;   // 队尾指针
} SqQueue;

// 初始化
void InitQueue(SqQueue *Q) {
    Q->front = Q->rear = 0;
}

// 判空
int QueueEmpty(SqQueue Q) {
    return Q.front == Q.rear;
}

// 判满(核心:牺牲1个元素)
int QueueFull(SqQueue Q) {
    return (Q.rear + 1) % MAXSIZE == Q.front;
}

// 入队
int EnQueue(SqQueue *Q, int e) {
    if (QueueFull(*Q)) {
        printf("队列已满!\n");
        return 0;
    }
    Q->data[Q->rear] = e;
    Q->rear = (Q->rear + 1) % MAXSIZE;
    return 1;
}

// 出队
int DeQueue(SqQueue *Q, int *e) {
    if (QueueEmpty(*Q)) {
        printf("队列已空!\n");
        return 0;
    }
    *e = Q->data[Q->front];
    Q->front = (Q->front + 1) % MAXSIZE;
    return 1;
}

// 测试
int main() {
    SqQueue Q;
    InitQueue(&Q);

    // 入队 4 个(满)
    EnQueue(&Q, 10);
    EnQueue(&Q, 20);
    EnQueue(&Q, 30);
    EnQueue(&Q, 40);
    EnQueue(&Q, 50);  // 失败:队列已满

    // 出队
    int e;
    while (!QueueEmpty(Q)) {
        DeQueue(&Q, &e);
        printf("出队:%d\n", e);
    }
    return 0;
}

方法2:增设标志位 flag

  • 思路:增加一个变量 flag,标记最近一次是入队还是出队

  • 队空:front == rear && flag == 0

  • 队满:front == rear && flag == 1

  • flag 规则:

    • 入队成功:flag = 1

    • 出队成功:flag = 0

  • 优点:不浪费空间,可存满 MAXSIZE 个元素

  • 缺点:多一个变量,逻辑稍复杂


方法3:增设计数器 count

  • 思路:用一个变量 count 记录队列中实际元素个数

  • 队空:count == 0

  • 队满:count == MAXSIZE

  • 入队:count++,出队:count--

  • 优点:直观,可存满 MAXSIZE 个元素,判空判满最清晰

  • 缺点:需要维护计数变量

相关推荐
CSharp精选营1 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
RainCity2 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
刘马想放假4 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠5 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
LinXunFeng9 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
Darling噜啦啦12 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
通信小呆呆13 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick13 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee13 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
小小工匠13 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化