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;
}

交换前:

交换后:

相关推荐
寻星探路1 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
lly2024063 小时前
Bootstrap 警告框
开发语言
2601_949146534 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
曹牧4 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
在路上看风景4 小时前
19. 成员初始化列表和初始化对象
c++
KYGALYX4 小时前
服务异步通信
开发语言·后端·微服务·ruby
zmzb01034 小时前
C++课后习题训练记录Day98
开发语言·c++
念风零壹4 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
猫头虎5 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
YUJIANYUE5 小时前
PHP纹路验证码
开发语言·php