【数据结构/C++】栈和队列_循环队列

牺牲一个存储单元来判断队满。

cpp 复制代码
#include<iostream>
using namespace std;
// 循环队列
#define MaxSize 10
typedef int ElemType;
typedef struct {
  ElemType data[MaxSize];
  int front, rear;
} SqQueue;
// 初始化队列
void InitQueue(SqQueue &Q) {
  // 判断队空 Q.rear == Q.front
  Q.front = Q.rear = 0;
}
// 入队
bool EnQueue(SqQueue &Q, ElemType x) {
  // 队尾指针的后一个位置为队头指针 即队满
  if((Q.rear + 1 % MaxSize == Q.front)) {
    return false;
  }
  // 队尾指针指向队尾元素的后一个位置
  Q.data[Q.rear] = x;
  // 队尾指针后移
  Q.rear = (Q.rear + 1) % MaxSize;
  return true;
}
// 出队
bool DeQueue(SqQueue &Q, ElemType &x) {
   if (Q.front == Q.rear) {
    return false;
   }
   x = Q.data[Q.front];
   Q.front = (Q.front + 1) % MaxSize;
   return true;
}
// 遍历
void Traverse(SqQueue Q) {
  for (int i = Q.front; i < Q.rear; i++) {
    cout << Q.data[i] << " ";
  }
  cout << endl;
}
// 长度
int QueueLength(SqQueue Q) {
  return (Q.rear - Q.front + MaxSize) % MaxSize;
}
int main() {
  SqQueue Q;
  InitQueue(Q);
  ElemType x;
  EnQueue(Q, 1);
  EnQueue(Q, 2);
  EnQueue(Q, 3);
  EnQueue(Q, 4);
  DeQueue(Q, x);
  cout << "出队元素为:" << x << endl;
  cout << "队列长度为:" << QueueLength(Q) << endl;
  Traverse(Q);
  return 0;
}

特殊地,如果队尾指针指向的是队尾元素:

cpp 复制代码
// 判断空
// 队尾指针的后一个位置就是队头指针
(Q.rear + 1) % MaxSize == Q.front
// 判断满
// 队尾指针的后两个位置就是队头指针,后一个位置为空

当然,还可以加一个变量比如 size 或者 tag 来进行判断。

相关推荐
曼巴UE517 分钟前
UE5.3 C++ 接口初步使用
开发语言·jvm·c++
奔跑的石头_21 分钟前
GO语言的主要语法和特性
开发语言
泛联新安23 分钟前
如何根据项目需求选择合适的软件测试工具?iUnit智能单元测试平台提供专业化解决方案
c++·测试工具·单元测试
曙曙学编程29 分钟前
stm32——NVIC,EXIT
c语言·c++·stm32·单片机·嵌入式硬件
liulilittle37 分钟前
UNIX/macOS路由表查询原理与实现
服务器·开发语言·c++·macos·unix·编程语言
HUST1 小时前
C语言 第三讲:分支和循环(上)
c语言·开发语言
Dovis(誓平步青云)2 小时前
《探索C++11:现代语法的性能优化策略(中篇)》
开发语言·c++
再努力"亿"点点2 小时前
爬取m3u8视频完整教程
开发语言·python
一个响当当的名号2 小时前
c++primer 个人学习总结-模板和泛型编程
开发语言·c++·学习
落羽的落羽2 小时前
【C++】C++11的可变参数模板、emplace接口、类的新功能
开发语言·c++·学习