菜单
×
   ❮     
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++ 堆栈

堆栈存储多个元素,顺序是特定的,称为LIFO

LIFO后进先出 的缩写。要形象地理解 LIFO,可以想象一叠煎饼,煎饼是同时从顶部添加和移除的。所以当移除一个煎饼时,它总是你最后添加的那个。这种组织元素的方式在计算机科学和编程中称为 LIFO。

向量 不同,堆栈中的元素不能通过索引号访问。由于元素是从顶部添加和移除的,您只能访问堆栈顶部的元素。

要使用堆栈,您必须包含 <stack> 头文件

// 包含 stack 库
#include <stack>

创建堆栈

要创建堆栈,请使用 stack 关键字,并指定它应存储的类型,放在尖括号 <> 中,然后是堆栈的名称,例如: stack<type> stackName

// 创建一个名为 cars 的字符串堆栈
stack<string> cars;

注意: 堆栈的类型(我们示例中的 string)在声明后不能更改。

注意:您不能在声明时添加元素,就像您可以对 向量 执行此操作一样

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

添加元素

要在堆栈中添加元素,请在声明堆栈后使用 .push() 函数

示例

// 创建一个名为 cars 的字符串堆栈
stack<string> cars;

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

堆栈将如下所示(记住最后添加的元素是顶部元素)

Mazda (顶部元素)
福特
宝马
沃尔沃


访问堆栈元素

您不能通过引用索引号来访问堆栈元素,就像您会使用 数组向量 一样。

在堆栈中,您只能访问顶部元素,这是使用 .top() 函数完成的

示例

// 访问顶部元素
cout << cars.top();  // 输出 "Mazda"
自己动手试一试 »

更改顶部元素

您还可以使用 .top 函数来更改顶部元素的值

示例

// 更改顶部元素的值
cars.top() = "Tesla";

 // 访问顶部元素
cout << cars.top();  // 现在输出 "Tesla" 而不是 "Mazda"
自己动手试一试 »

移除元素

您可以使用 .pop() 函数从堆栈中删除元素。

这将删除最后添加到堆栈的元素

示例

// 创建一个名为 cars 的字符串堆栈
stack<string> cars;

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

// 删除最后添加的元素 (Mazda)
cars.pop();

// 访问顶部元素 (现在是 Ford)
cout << cars.top();
自己动手试一试 »

获取堆栈的大小

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

示例

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

检查堆栈是否为空

使用 .empty() 函数来判断堆栈是否为空。

如果堆栈为空,.empty() 函数返回 1 (true),否则返回 0 (false)

示例

stack<string> cars;
cout << cars.empty(); // 输出 1 (堆栈为空)
自己动手试一试 »

示例

stack<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 提供支持