菜单
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

C++ 教程

C++ 主页 C++ 简介 C++ 入门 C++ 语法 C++ 输出 C++ 注释 C++ 变量 C++ 用户输入 C++ 数据类型 C++ 运算符 C++ 字符串 C++ 数学 C++ 布尔值 C++ If...Else C++ Switch C++ While 循环 C++ For 循环 C++ Break/Continue C++ 数组 C++ 结构体 C++ 枚举 C++ 引用 C++ 指针

C++ 函数

C++ 函数 C++ 函数参数 C++ 函数重载 C++ 作用域 C++ 递归

C++ 类

C++ OOP C++ 类/对象 C++ 类方法 C++ 构造函数 C++ 访问修饰符 C++ 封装 C++ 继承 C++ 多态 C++ 文件 C++ 异常 C++ 日期

C++ 数据结构

C++ 数据结构与 STL C++ Vectors C++ List C++ Stacks C++ Queues C++ Deque C++ Sets C++ Maps C++ 迭代器 C++ 算法

C++ How To

C++ 两数相加 C++ 随机数

C++ 参考

C++ 参考 C++ 关键字 C++ <iostream> C++ <fstream> C++ <cmath> C++ <string> C++ <cstring> C++ <ctime> C++ <vector> C++ <algorithm>

C++ 示例

C++ 示例 C++ 现实生活中的例子 C++ 编译器 C++ 练习 C++ 测验 C++ 证书


C++ 队列


C++ 队列

队列存储多个元素,遵循特定的顺序,称为FIFO

FIFO 代表先进先出。要理解 FIFO,可以想象超市里排队的人。第一个排队的人也是第一个可以付款离开超市的人。这种组织元素的方式在计算机科学和编程中称为 FIFO。

vector 不同,队列中的元素不能通过索引号访问。由于队列元素在末尾添加,在开头移除,您只能访问开头或末尾的元素。

要使用队列,您必须包含 <queue> 头文件

// 包含 queue 库
#include <queue>

创建队列

要创建队列,请使用 queue 关键字,并在尖括号 <> 中指定它应存储的值的类型,然后是队列的名称,例如:queue<type> queueName

// 创建一个名为 cars 的字符串队列
queue<string> cars;

注意:队列的类型(在我们示例中为 string)在声明后无法更改。

注意:您不能在声明时添加元素,就像您可以对 vector 所做的那样

queue<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

添加元素

要将元素添加到队列,您可以在声明队列后使用 .push() 函数。

.push() 函数将元素添加到队列的末尾

示例

// 创建一个字符串队列
queue<string> cars;

// 向队列添加元素
cars.push("Volvo");
cars.push("BMW");
cars.push("Ford");
cars.push("Mazda");

队列将如下所示

Volvo (队首(第一个)元素)
宝马
福特
Mazda (队尾(最后一个)元素)


访问队列元素

您无法像使用 数组vector 那样通过索引号访问队列元素。

在队列中,您只能使用 .front().back() 分别访问队首或队尾的元素。

示例

// 访问队首元素(第一个也是最旧的)
cout << cars.front();  // 输出 "Volvo"

// 访问队尾元素(最后一个也是最新的)
cout << cars.back();  // 输出 "Mazda"
自己动手试一试 »

更改队首和队尾元素

您还可以使用 .front.back 来更改队首和队尾元素的值。

示例

// 更改队首元素的值
cars.front() = "Tesla";

// 更改队尾元素的值
cars.back() = "VW";

// 访问队首元素
cout << cars.front();  // 现在输出“Tesla”,而不是“Volvo”

// 访问队尾元素
cout << cars.back();  // 现在输出“VW”,而不是“Mazda”
自己动手试一试 »

移除元素

您可以使用 .pop() 函数从队列中移除一个元素。

这将移除队首元素(添加到队列的第一个也是最旧的元素)。

示例

// 创建一个字符串队列
queue<string> cars;

// 向队列添加元素
cars.push("Volvo");
cars.push("BMW");
cars.push("Ford");
cars.push("Mazda");

// 移除队首元素 (Volvo)
cars.pop();

// 访问队首元素(现在是 BMW)
cout << cars.front();
自己动手试一试 »

获取队列的大小

要查找队列中有多少个元素,请使用 .size() 函数。

示例

cout << cars.size();
自己动手试一试 »

检查队列是否为空

使用 .empty() 函数来查找队列是否为空。

.empty() 函数在队列为空时返回 1true),否则返回 0false)。

示例

queue<string> cars;
cout << cars.empty(); // 输出 1(队列为空)
自己动手试一试 »

示例

queue<string> cars;

cars.push("Volvo");
cars.push("BMW");
cars.push("Ford");
cars.push("Mazda");

cout << cars.empty();  // 输出 0 (非空)
自己动手试一试 »

栈和队列

队列经常与 一起提及,栈是上一页中描述的类似数据结构。


×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持