1.基本概念
- stack是一种先进后出的数据结构,它只有一个出口,只能从栈顶对栈进行操作。
- 栈中所有元素必须符合先进后出规则,所以栈不提供走访功能,也不提供迭代器(iterator)栈中只有栈顶元素才能被访问,因此栈不允许有遍历行为。
- STL中栈往往不被归类为容器,而被归类为container adapter(容器适配器)。
- 使用时须加 #include<stack> 头文件
2.栈的常用接口
构造函数
-
stack<T> stk;
//stack采用模板类实现, stack对象的默认构造形式 -
stack(const stack &stk);
//拷贝构造函数
赋值操作:
-
stack& operator=(const stack &stk);
//重载等号操作符
数据存取:
-
push(elem);
//向栈顶添加元素 -
pop();
//从栈顶移除第一个元素 -
top();
//返回栈顶元素
大小操作:
-
empty();
//判断堆栈是否为空 -
size();
//返回栈的大小
示例
#include <iostream>
#include <stack>
using namespace std;
int main() {
//创建栈容器 栈容器必须符合先进后出
stack<int> s;
//向栈中添加元素,叫做 压栈 入栈
s.push(10);
s.push(20);
s.push(30);
while (!s.empty()) {
//输出栈顶元素
cout << "栈顶元素为: " << s.top() << endl;
//弹出栈顶元素
s.pop();
}
cout << "栈的大小为:" << s.size() << endl;
return 0;
}
3.总结:
-
入栈 --- push
-
出栈 --- pop
-
返回栈顶 --- top
-
判断栈是否为空 --- empty
-
返回栈大小 --- size