STL 容器:stack

目录

  • [1 stack 的概念](#1 stack 的概念)
  • [2 stack 的构造方式](#2 stack 的构造方式)
  • [2 stack 的常用接口](#2 stack 的常用接口)
    • [2.2 stack 的操作](#2.2 stack 的操作)
      • [2.2.1 empty()](#2.2.1 empty())
      • [2.2.2 size()](#2.2.2 size())
      • [2.2.3 top()](#2.2.3 top())
      • [2.2.4 push()](#2.2.4 push())
      • [2.2.5 pop()](#2.2.5 pop())
      • [2.2.6 swap()](#2.2.6 swap())

stack 的技术文档: 文档链接

1 stack 的概念

stack 是 STL 容器之一,它实现自数据结构当中的栈

与数据结构中的栈相同,stack 也只能在栈顶插入数据,删除数据,遵循后进先出的原则

要注意,这里的栈指的不是内存当中用来存放形参,局部变量的栈,而是一种用来存放数据,操作受限的线性表

要使用 stack,就需要包含头文件 stack,由于容器都是定义在 std 命名空间下的,所以还需要指定命名空间 std

cpp 复制代码
#include <stack>

2 stack 的构造方式

在构造 stack 时,要使用以下的语法:

cpp 复制代码
stack<数据类型, 内部所用的数据结构> 对象名();

其中,数据类型和对象名是必须要给定的,内部所用的数据结构与括号这两个信息不是必须的,如果不指定内部所用的数据结构,那么 stack 的内部用的结构就是 deque(一种顺序表和链表的结合),指定了内部所用的数据结构则使用指定的。

构造 stack 有两个方式:

(1)构造空的 stack

对象名后不加括号,就是在构造空的 stack

cpp 复制代码
int main()
{
	stack<int> s1;
	return 0;
}

(2)通过已有的容器对象来构造 stack

用这种方式构造 stack 时,需要将 stack 内部所用的数据结构更改为用来初始化 stack 的容器对象的结构

cpp 复制代码
int main()
{
	vector<int> v1(2, 200); //用来初始化栈的vector
	stack<int, vector<int>> s1(v1); //构造栈所用的数据结构需要更改为vector
	return 0;
}

2 stack 的常用接口

2.2 stack 的操作

stack 的操作主要有:

接口名称 功能
empty 检查栈是否为空
size 获取栈中的元素个数
top 获取栈顶元素
push 将元素插入到栈顶
pop 将栈顶元素移除
swap 交换两个栈中的值

2.2.1 empty()

empty 的功能主要是检查栈是否为空,是空返回 true,非空则返回 false

cpp 复制代码
int main()
{
	stack<int> s1;
	if (s1.empty())
		cout << "s1 is empty" << endl;
	else
		cout << "s1 is not empty" << endl;

	stack<int> s2;
	s2.push(1);
	s2.push(2); //插入两个值到栈中
	if (s2.empty())
		cout << "s2 is empty" << endl;
	else
		cout << "s2 is not empty" << endl;

	return 0;
}

最终的结果为:

cpp 复制代码
s1 is empty
s2 is not empty

2.2.2 size()

size() 的主要功能是获取栈内元素的个数

cpp 复制代码
int main()
{
	stack<int> s1;
	s1.push(1);
	s1.push(2);
	cout << s1.size() << endl;
	return 0;
}

最终结果为:

cpp 复制代码
2

2.2.3 top()

top 的作用主要是获取栈顶的元素

cpp 复制代码
int main()
{
	stack<int> s1;
	s1.push(1);
	s1.push(2);
	cout << s1.top() << endl;
	return 0;
}

最终结果为:

cpp 复制代码
2

2.2.4 push()

push 的作用主要是将元素入栈并更新size,入栈后,该元素位于栈顶

cpp 复制代码
int main()
{
	stack<int> s1;
	s1.push(1);
	s1.push(2);
	return 0;
}

2.2.5 pop()

pop 的作用主要是将栈顶元素出栈并更新 size

cpp 复制代码
int main()
{
	stack<int> s1;
	s1.push(1);
	s1.push(2);
	s1.pop();
	return 0;
}

2.2.6 swap()

swap 的作用主要是交换两个栈中的内容

cpp 复制代码
int main()
{
	stack<int> s1;
	s1.push(1);
	s1.push(2);

	stack<int> s2;
	s2.push(5);
	s2.push(6);

	s1.swap(s2);
	return 0;
}

交换前:

交换后:

相关推荐
CoderCodingNo20 小时前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
陳103020 小时前
C++:红黑树
开发语言·c++
一切尽在,你来20 小时前
C++ 零基础教程 - 第 6 讲 常用运算符教程
开发语言·c++
泉-java20 小时前
第56条:为所有导出的API元素编写文档注释 《Effective Java》
java·开发语言
weixin_4997715521 小时前
C++中的组合模式
开发语言·c++·算法
初级代码游戏21 小时前
套路化编程 C# winform 自适应缩放布局
开发语言·c#·winform·自动布局·自动缩放
_waylau21 小时前
鸿蒙架构师修炼之道-架构师的职责是什么?
开发语言·华为·harmonyos·鸿蒙
2的n次方_21 小时前
CANN Ascend C 编程语言深度解析:异构并行架构、显式存储层级与指令级精细化控制机制
c语言·开发语言·架构
近津薪荼21 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck21 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl