蓝桥杯省赛无忧 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;
}
相关推荐
重生之后端学习6 小时前
136. 只出现一次的数字
开发语言·算法·leetcode·职场和发展·深度优先
smj2302_796826527 小时前
解决leetcode第3869题.统计区间内奇妙数的数目
python·算法·leetcode
witAI7 小时前
**Sora仿真人剧2025推荐,解锁沉浸式互动叙事新体验*
c++
CodeCraft Studio7 小时前
Parasoft C/C++嵌入式软件测试解决方案:安全、可靠且符合标准
开发语言·c++·安全·单元测试·代码规范·parasoft·嵌入式软件测试
TracyCoder1237 小时前
LeetCode Hot100(66/100)——118. 杨辉三角
算法·leetcode·职场和发展
葳_人生_蕤7 小时前
Leetcode HOT 100
算法·leetcode·职场和发展
仟濹7 小时前
【算法打卡day23(2026-03-15 周日)今日算法or技巧:双指针 & 链表 & 回溯算法】6个题
数据结构·算法·链表
跃龙客7 小时前
C++写文件笔记
c++·笔记
Je1lyfish7 小时前
CMU15-445 (2026 Spring) Project#2 - B+ Tree
linux·数据结构·数据库·c++·sql·spring·oracle
永远睡不够的入7 小时前
C++STL详解2:stack和queue
开发语言·c++