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 个元素,判空判满最清晰

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

相关推荐
biuyyyxxx2 小时前
Power Query功能区 - 主页
笔记·学习·excel
liuyao_xianhui2 小时前
优选算法_翻转链表_头插法_C++
开发语言·数据结构·c++·算法·leetcode·链表·动态规划
Book思议-2 小时前
【数据结构实战】循环队列FIFO 特性生成六十甲子(天干地支纪年法),实现传统文化里的 “时间轮回”
数据结构·算法·
m0_651562522 小时前
2026.3.23搭建AI算法可视化部署演示学习笔记
笔记·学习
renhongxia12 小时前
学习如何聚合零样本大型语言模型代理以进行企业披露分类
学习·语言模型·分类
im_AMBER2 小时前
Leetcode 147 零钱兑换 | 单词拆分
javascript·学习·算法·leetcode·动态规划
CODE_RabbitV2 小时前
STM32F103C8T6 理论部分学习笔记
笔记·stm32·学习
cpp_25013 小时前
P1796 汤姆斯的天堂梦
数据结构·c++·算法·题解·洛谷·线性dp
snowfoootball3 小时前
自用常用提示词库(建设中)
学习