C++ stack 的使用

目录

[1. 无参构造函数](#1. 无参构造函数)

[2. void push(const T& x)](#2. void push(const T& x))

[3. void pop()](#3. void pop())

[4. T& top()](#4. T& top())

[5. bool empty()](#5. bool empty())

[6. size_t size()](#6. size_t size())

[7. 总结](#7. 总结)


  1. stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行 元素的插入与提取操作。

  2. stack是作为容器适配器被实现的,容器适

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

using namespace std;

int main()
{
	stack<int> st;
	return 0;
}

配器即是对特定类封装作为其底层的容器,并提供一组特定 的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部(即栈顶)被压入和弹出。

  1. stack的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类,这些容器类应该支持以下 操作: empty:判空操作 back:获取尾部元素操作 push_back:尾部插入元素操作 pop_back:尾部删除元素操作

  2. 标准容器vector、deque、list均符合这些需求,默认情况下,如果没有为stack指定特定的底层容器, 默认情况下使用deque。

上面的内容仅作了解,具体的理解过程会在 stack 的模拟实现部分讲解。

1. 无参构造函数

在 stack 底层,其实使用 STL 的一种容器适配出来的 stack。stack 的无参构造是用得最多的!当然 stack 肯定是有拷贝构造的撒!

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

using namespace std;

int main()
{
	stack<int> st;
	return 0;
}

2. void push(const T& x)

这个函数可以向栈顶插入一个元素。

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

using namespace std;

int main()
{
	stack<int> st;
	st.push(1);
	return 0;
}

3. void pop()

这个元素也很简单,就是弹出栈顶的元素!

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

using namespace std;

int main()
{
	stack<int> st;
	st.push(1);
	st.pop();
	return 0;
}

4. T& top()

返回栈顶的元素。

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

using namespace std;

int main()
{
	stack<int> st;
	st.push(1);
	st.push(2);
	st.push(3);

	cout << st.top() << endl; //输出:3
	return 0;
}

5. bool empty()

个函数可以判断一个栈是否为空!为空返回 true,不为空返回 false。

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

using namespace std;

int main()
{
	stack<int> st;
	st.push(1);
	st.push(2);
	st.push(3);

	cout << st.empty() << endl; //输出:0
	return 0;
}

6. size_t size()

返回栈中元素的个数。

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

using namespace std;

int main()
{
	stack<int> st;
	st.push(1);
	st.push(2);
	st.push(3);

	cout << st.size() << endl; //输出:3
	return 0;
}

7. 总结

栈是没有迭代器的,他不支持遍历数据。栈只是一种规定了数据插入,删除方式的一种容器。十分简单呢!

相关推荐
2301_7644413323 分钟前
Python构建输入法应用
开发语言·python·算法
咨询QQ2769988535 分钟前
V-REP小车项目+匹配文档,基于V-REP与MATLAB联合仿真,小车能够完成循迹、避障、走...
开发语言
咩图36 分钟前
C#创建AI项目
开发语言·人工智能·c#
豆沙沙包?1 小时前
2025年--Lc293-784. 字母大小写全排列(回溯)--java版
java·开发语言
珑墨2 小时前
【唯一随机数】如何用JavaScript的Set生成唯一的随机数?
开发语言·前端·javascript·ecmascript
周杰伦fans2 小时前
C# - Task 是什么?想象一下你在餐厅点餐
服务器·开发语言·c#
芳草萋萋鹦鹉洲哦2 小时前
【tauri+rust】App会加载白屏,有时显示在左上角显示一小块,如何优化
开发语言·后端·rust
前端世界2 小时前
float 还是 double?用储罐体积计算带你看懂 C 语言浮点数的真实世界坑
java·c语言·开发语言
豐儀麟阁贵2 小时前
8.5在方法中抛出异常
java·开发语言·前端·算法