当前位置: 首页 > news >正文

C++ 用数组模拟队列

在C++中,使用数组模拟队列通常涉及到两个主要的操作:入队(enqueue)和出队(dequeue)。由于数组是一个固定大小的数据结构,当使用数组模拟队列时,需要手动管理队列的头部和尾部位置。以下是使用数组模拟队列的一种简单实现方法:

#include <iostream>
#include <vector>class ArrayQueue {
private:std::vector<int> data; // 使用vector来动态管理数组的大小int front; // 队列头部的索引int rear;  // 队列尾部的索引int count; // 队列中元素的数量public:ArrayQueue() : front(0), rear(-1), count(0) {}// 入队操作bool enqueue(int value) {if (count == data.size()) {// 如果队列满了,需要扩容if (data.size() == 0 || rear == 0) {data.resize(data.size() * 2);} else {// 将队列元素向前移动,重新利用数组空间for (int i = front; i != rear + 1; ++i) {data[i - front] = data[i];}rear -= front;front = 0;}}data[++rear] = value;++count;return true;}// 出队操作bool dequeue() {if (count == 0) {std::cout << "Queue is empty" << std::endl;return false;}if (front == rear) {// 队列为空,重置front和rearfront = rear = 0;} else {++front;}--count;return true;}// 查看队首元素int frontValue() const {if (count == 0) {throw std::runtime_error("Queue is empty");}return data[front];}// 检查队列是否为空bool isEmpty() const {return count == 0;}// 获取队列的大小int size() const {return count;}
};int main() {ArrayQueue queue;queue.enqueue(1);queue.enqueue(2);queue.enqueue(3);std::cout << "Front value: " << queue.frontValue() << std::endl; // 输出队首元素queue.dequeue();std::cout << "Front value after dequeue: " << queue.frontValue() << std::endl;std::cout << "Queue size: " << queue.size() << std::endl; // 输出队列大小while (!queue.isEmpty()) {std::cout << "Dequeued: " << queue.frontValue() << std::endl;queue.dequeue();}return 0;
}

这个例子中,我们使用了 std::vector 来避免固定大小数组带来的限制,使得队列可以根据需要自动扩容。front 和 rear 分别指向队列的头部和尾部,count 记录队列中的元素数量。

请注意,当数组填满时,我们可以选择扩容数组或者将数组中的元素向前移动,以重新利用数组空间。在这个例子中,我们选择了后者,这样可以避免频繁的内存分配和复制操作。但是,这种方法要求数组的初始位置不为0,或者在移动元素后更新 front 和 rear 的值。

http://www.lryc.cn/news/365154.html

相关文章:

  • 每日一题34:数据分组之查找每个员工花费的总时间
  • 语言模型解构——Tokenizer
  • 前端经验:导出表格为excel并设置样式
  • UFS协议—新手快速入门(二)【5-6】
  • 手机建站介绍
  • windows11 安装cnpm 报错 Error: EPERM: operation not permitted 没权限
  • SQL 如何获取A列相同但是B列不同的数据项
  • 如何在QGIS中加载高清卫星影像?
  • 后端返回图片格式乱码
  • C++基础编程100题-025 OpenJudge-1.4-05 整数大小比较
  • [office] 16种常见的COUNTIF函数公式设置 #笔记#职场发展
  • spring boot2.7.x遇到问题
  • Webpack 开发快速入门
  • AI时代的多维探索
  • 您的游戏端被攻击了怎么办,德迅云安全的应用加速来帮您
  • 关于利用hashcat破解WiFi数据包的操作记录
  • 伯克希尔·哈撒韦:“股神”的“登神长阶”
  • f1c100s 荔枝派 系统移植
  • EtherCAT 和 UDP 通讯的实时性 区别
  • 山东大学软件学院项目实训-创新实训-基于大模型的旅游平台(二十八)- 微服务(8)
  • 如何将 MySQL 数据库共享给他人?
  • netty-学习
  • 无线和移动网络
  • 快团团账号被封,大团长帮卖团长如何避免违规操作
  • Github Copilot登录账号,完美支持chat
  • Ubuntu系统中Apache Web服务器的配置与实战
  • 如何在路由器上安装代理服务:详细教程
  • JavaScript html css前端 日期对象 date对象 日期格式化 时间戳
  • 【再探】设计模式—备忘录模式与解释器模式
  • SpringCloud网关-gateway