首页 > 后端开发 > C++ > 正文

C++如何实现一个队列(Queue)_C++数据结构之先进先出(FIFO)的实现

裘德小鎮的故事
发布: 2025-12-05 12:26:02
原创
507人浏览过
答案:C++中队列可通过链表、循环数组或STL实现,链表法便于理解FIFO原理,循环队列节省空间,STL的queue最实用。

c++如何实现一个队列(queue)_c++数据结构之先进先出(fifo)的实现

在C++中实现一个队列(Queue),核心是遵循先进先出(FIFO, First In First Out)的原则。可以通过数组、链表或使用STL容器来实现。下面从零开始,介绍如何手动实现一个基于链表的队列,并简要说明其他实现方式。

1. 链表实现队列(推荐初学者理解原理)

使用单向链表可以高效地实现队列,其中队头用于出队(dequeue),队尾用于入队(enqueue),避免频繁移动数据。

struct Node { int data; Node* next; Node(int val) : data(val), next(nullptr) {} };

class Queue { private: Node front; // 指向队头 Node rear; // 指向队尾

public: Queue() : front(nullptr), rear(nullptr) {}

// 入队:在队尾添加元素
void enqueue(int val) {
    Node* newNode = new Node(val);
    if (rear == nullptr) {
        front = rear = newNode;
    } else {
        rear->next = newNode;
        rear = newNode;
    }
}

// 出队:从队头移除元素
void dequeue() {
    if (front == nullptr) {
        std::cout << "队列为空,无法出队\n";
        return;
    }
    Node* temp = front;
    front = front->next;
    if (front == nullptr) {
        rear = nullptr;  // 队列变空时更新rear
    }
    delete temp;
}

// 获取队头元素
int getFront() {
    if (front == nullptr) {
        throw std::runtime_error("队列为空");
    }
    return front->data;
}

// 判断队列是否为空
bool isEmpty() {
    return front == nullptr;
}

// 析构函数:释放内存
~Queue() {
    while (front != nullptr) {
        Node* temp = front;
        front = front->next;
        delete temp;
    }
}
登录后复制

};

2. 使用动态数组实现循环队列(节省空间)

如果用数组实现,为了避免大量数据前移,可采用“循环队列”结构,通过取模操作复用空间。

class CircularQueue { private: int* arr; int front, rear; int capacity; int count;

public: CircularQueue(int size) { capacity = size; arr = new int[capacity]; front = 0; rear = -1; count = 0; }

void enqueue(int val) {
    if (count == capacity) {
        std::cout << "队列已满\n";
        return;
    }
    rear = (rear + 1) % capacity;
    arr[rear] = val;
    count++;
}

void dequeue() {
    if (count == 0) {
        std::cout << "队列为空\n";
        return;
    }
    front = (front + 1) % capacity;
    count--;
}

int getFront() {
    if (count == 0) throw std::runtime_error("队列为空");
    return arr[front];
}

bool isEmpty() {
    return count == 0;
}

~CircularQueue() {
    delete[] arr;
}
登录后复制

};

3. 使用STL中的queue(实际开发推荐)

在实际编程中,建议直接使用C++标准库提供的queue,它封装了底层细节,安全高效。

立即学习C++免费学习笔记(深入)”;

畅图
畅图

AI可视化工具

畅图 179
查看详情 畅图
#include #include iostream>

std::queue q;

q.push(10); // 入队 q.push(20); if (!q.empty()) { std::cout

说明: STL的queue默认基于deque实现,也可指定list或vector作为底层容器。

4. 关键点总结

实现队列时需要注意以下几点:

  • 保持front和rear指针(或下标)正确更新
  • 处理空队列和满队列的边界情况
  • 链表实现注意内存释放,防止泄漏
  • 循环队列中使用取模实现“环形”逻辑
  • 所有基本操作应尽量保持O(1)时间复杂度

基本上就这些。手动实现有助于理解FIFO机制,而项目中优先使用STL更稳妥。

以上就是C++如何实现一个队列(Queue)_C++数据结构之先进先出(FIFO)的实现的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号