C/C++数据结构之队列基础

概述

与前面几篇文章中介绍的栈不同,栈是后进先出,而队列是先进先出。队列最直观的例子就是:人们在银行、餐厅或售票窗口前排队等候服务。最早到达的人会最先得到服务,这与队列的操作原则基本一致。

原理

队列作为一种基础的数据结构,遵循先进先出(FIFO, 即First-In-First-Out)的原则。其核心概念主要包括如下三点。

1、先进先出。队列的基本特性是遵循先进先出的原则,这意味着,最先加入队列的元素会首先被移除。

2、入队。向队尾添加一个元素,这是将新元素加入队列的操作,保证了该元素会在所有先前加入的元素之后被处理。

3、出队。从队首移除一个元素,这是从队列中取出下一个待处理元素的操作,确保了根据FIFO原则选择正确的元素进行处理。

我们可以把队列想象成这样一个箱子:它有两个口,分别叫做队首和队尾;所有东西都必须从队首这个口进去,从队尾那个口出来。放东西进去,叫入队(Enqueue)。拿东西出来,叫出队(Dequeue)。

在下面的表格中,我们在不同时间对箱子做了不同的动作。可以看到,越先放进箱子里的东西,越早被拿出来。

时间 动作 箱子里的内容
第1秒 Enqueue A A
第2秒 Enqueue B A, B
第3秒 Enqueue C A, B, C
第4秒 Dequeue B, C → 弹出的是A
第5秒 Dequeue C → 弹出的是B

STL中的队列

在C++ STL标准模板库中,已经提供了队列这种数据结构,即std::queue。如何使用std::queue,可以参考下面的示例代码。

cpp 复制代码
#include <iostream>
#include <queue>

using namespace std;

int main()
{
    queue<int> q;

    q.push(66);
    q.push(77);
    q.push(88);

    while (!q.empty())
    {
        cout << q.front() << " ";
        q.pop();
    }

    return 0;
}

总结

队列是一种遵循先进先出原则的线性数据结构,适用于需要按照顺序处理任务的场景,广泛应用于操作系统、网络通信、算法设计等多个领域。在C/C++中,队列可以通过数组或链表来实现,我们会在后续的文章中专门进行介绍。

相关推荐
CSharp精选营17 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
用户805533698031 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境2 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境2 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
郝学胜_神的一滴3 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
刘马想放假4 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠5 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
卷无止境5 天前
C++ 的Eigen 库全解析
c++
卷无止境5 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端