C++实现环形队列:从基本运算到完整操作示例(sqqueue.cpp与exp2-2.cpp详解)
好的,下面是一个实现环形队列的基本操作的C++程序 `sqqueue.cpp`,以及一个使用该环形队列的示例程序 `exp2-2.cpp`。 sqqueue.cpp ```cpp #include <iostream> #include <cstring> const int MAX_SIZE = 100; class SqQueue { private: char data[MAX_SIZE]; int front; int rear; int capacity; public: SqQueue(int size = MAX_SIZE) : capacity(size) { front = rear = 0; } ~SqQueue() { // 清理资源 } bool is_empty() const { return front == rear; } bool is_full() const { return (rear + 1) % capacity == front; } bool enqueue(char x) { if (is_full()) { return false; } data[rear] = x; rear = (rear + 1) % capacity; return true; } bool dequeue(char &x) { if (is_empty()) { return false; } x = data[front]; front = (front + 1) % capacity; return true; } void clear() { front = rear = 0; } }; int main() { SqQueue q(10); std::cout << "初始化队列q" << std::endl; if (q.is_empty()) { std::cout << "队列q为空" << std::endl; } else { std::cout << "队列q不为空" << std::endl; } std::cout << "依次插入a、b、c" << std::endl; q.enqueue('a'); q.enqueue('b'); q.enqueue('c'); char x; if (q.dequeue(x)) { std::cout << "出队一个元素: " << x << std::endl; } std::cout << "依次进队d、e、f" << std::endl; q.enqueue('d'); q.enqueue('e'); q.enqueue('f'); std::cout << "输出出队序列: "; while (!q.is_empty()) { if (q.dequeue(x)) { std::cout << x << " "; } } std::cout << std::endl; std::cout << "释放队列q" << std::endl; q.clear(); return 0; } ``` exp2-2.cpp ```cpp #include "sqqueue.cpp" int main() { SqQueue q(10); std::cout << "初始化队列q" << std::endl; if (q.is_empty()) { std::cout << "队列q为空" << std::endl; } else { std::cout << "队列q不为空" << std::endl; } std::cout << "依次插入a、b、c" << std::endl; q.enqueue('a'); q.enqueue('b'); q.enqueue('c'); char x; if (q.dequeue(x)) { std::cout << "出队一个元素: " << x << std::endl; } std::cout << "依次进队d、e、f" << std::endl; q.enqueue('d'); q.enqueue('e'); q.enqueue('f'); std::cout << "输出出队序列: "; while (!q.is_empty()) { if (q.dequeue(x)) { std::cout << x << " "; } } std::cout << std::endl; std::cout << "释放队列q" << std::endl; q.clear(); return 0; } ``` 说明 1. sqqueue.cpp: - 定义了一个环形队列类 `SqQueue`,支持基本的队列操作:初始化、判空、判满、入队、出队和清空。 - 在 `main` 函数中演示了如何使用这个类来完成题目要求的操作。 2. exp2-2.cpp: - 直接包含了 `sqqueue.cpp` 文件,这样可以复用 `SqQueue` 类的实现。 - 在 `main` 函数中实现了题目要求的功能。 你可以将这两个文件分别保存,并编译运行 `exp2-2.cpp` 来验证程序的正确性。 ######[AI写代码神器 | 962点数解答 | 2024-10-20 17:59:23]
- 用队列操作算法模拟周末舞会舞伴配对问题及代码实现(DeepSeek | 601点数解答 | 2025-05-18 11:27:45)184
- C++实现超全功能文字版象棋游戏:多文件代码大揭秘!(字节豆包 | 2285点数解答 | 2025-12-20 08:21:39)34
- Python实现Q老师成绩管理任务:修改与查看学生成绩(字节豆包 | 191点数解答 | 2025-12-20 20:55:41)75
- Python 代码助力 Q 老师高效管理班级学生成绩:修改与查看一键搞定(字节豆包 | 326点数解答 | 2025-12-27 20:48:12)74
- Java实现链表反转:迭代与递归双解法详解及开发实战指南(DeepSeek | 1409点数解答 | 2026-03-15 15:09:29)24
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)345
- 解决 consoleapplication40.cpp 中 buildtree 模板参数推导失败错误的方法(字节豆包 | 138点数解答 | 2024-11-10 23:42:06)241
- 深度揭秘 Oracle Workarea Size Policy:参数调优助力数据库性能飞升(阿里通义 | 372点数解答 | 2024-05-13 10:54:45)229
- 探寻数组中最长摆动子序列长度:思路剖析与代码优化(GPT | 758点数解答 | 2024-12-23 23:18:29)267
- 独家剖析:求解数组最长摆动子序列长度的代码实现与改进建议(GPT | 350点数解答 | 2024-12-23 23:20:54)263
- C++ 实现我的世界基岩版:从简单框架到开发要点揭秘(字节豆包 | 182点数解答 | 2025-02-22 15:53:11)197
- “才女”技能揭秘:用牌时可跨类型出牌!(字节豆包 | 43点数解答 | 2025-07-31 10:26:35)183