蓝桥杯省赛无忧 STL 课件14 stack

01 stack的定义和结构

stack是一种后进先出(LIFO)的数据结构,使用前需要包含头文件。

stack提供了一组函数来操作和访问元素,但它的功能相对较简单。

stack的定义和结构如下(仅作了解即可):

csharp 复制代码
template <class T,class Container = deque<T>>
class stack;

T:表示存储在stack中的元素的类型。

Container:表示底层容器的类型,默认为deque.也可以使用其他容器类型,如vector或list.

stack的内部实现使用了底层容器来存储元素,并且只能通过特定的函数来访问和操作元素。

02 stack的常用函数

03 代码示例

csharp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	stack<int> myStack;
	//向栈中插入元素
	myStack.push(10);
	myStack.push(20);
	myStack.push(30);
	myStack.push(40);
	//获取栈顶元素
	cout<<"栈顶元素:"<<myStack.top()<<endl;
	//弹出栈顶元素
	myStack.pop();
	//再次获取栈顶元素
	cout<<"弹出一个元素后的栈顶元素"<<myStack.top()<<endl;
	//检查栈是否为空
	if(myStack.empty()){
		cout<<"栈为空"<<endl;
	}else{
		cout<<"栈不为空"<<endl;
	}
	//获取栈的大小
	cout<<"栈的大小: "<<myStack.size()<<endl; 
	return 0;
}
相关推荐
一方热衷.23 分钟前
YOLO26-Seg ONNXruntime C++/python推理
开发语言·c++·python
炽烈小老头2 小时前
【每天学习一点算法 2026/03/08】相交链表
学习·算法·链表
一碗白开水一2 小时前
【工具相关】OpenClaw 配置使用飞书:打造智能飞书助手全流程指南(亲测有效,放心享用)
人工智能·深度学习·算法·飞书
仰泳的熊猫3 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
Tisfy3 小时前
LeetCode 1888.使二进制字符串字符交替的最少反转次数:前缀和O(1)
算法·leetcode·字符串·题解
2301_803554523 小时前
linux 以及 c++编程里对于进程,线程的操作
linux·运维·c++
滴滴答滴答答4 小时前
机考刷题之 9 LeetCode 503 下一个更大元素 II
算法·leetcode·职场和发展
飞Link4 小时前
梯度下降的优化算法中,动量算法和指数加权平均的区别对比
人工智能·深度学习·算法
啊哦呃咦唔鱼4 小时前
LeetCode hot100-15 三数之和
数据结构·算法·leetcode