数据结构:STL:queue stack

目录

1.queue的头文件

2.queue的定义

3.queue的常用函数

[3.1 push()](#3.1 push())

[3.2 pop()](#3.2 pop())

[3.3 size()](#3.3 size())

[3.4 empty()](#3.4 empty())

[3.5 front()](#3.5 front())

[3.6 back()](#3.6 back())

4.stack的头文件

5.stack的定义

6.stack的常用函数

[6.1 push()](#6.1 push())

[6.2 top()](#6.2 top())

[6.3 pop()](#6.3 pop())

[6.4 size()](#6.4 size())

[6.6 empty()](#6.6 empty())


STLf封装的queue也是十分的强大,一个queue不但可以实现队列,还可以实现循环队列。、

1.queue的头文件

复制代码
#include<queue>

2.queue的定义

queue的定义和vector没什么不同

复制代码
queue<类型名>变量名;

类型可以是int,double等基本数据类型,也可以是自定义的结构体,也可以是STL容器。

复制代码
queue<int>q;
queue<double>q;
queue<char>q;
queue<char,list<char>>q;

3.queue的常用函数

3.1 push()

push()在队尾插入一个元素

复制代码
queue<int>q;
q.push(1);
q.push(2);
cout<<q.front()<<endl;

输出:

复制代码
1

3.2 pop()

pop()删除队首元素

复制代码
qqueue<int>q;
q.push(1);
q.push(2);
q.pop();
cout<<q.front()<<endl;

输出:

复制代码
2 //1已经被删除掉

3.3 size()

size()返回队列中元素个数

复制代码
1
0

queue<int>q;
q.push(1);
q.push(2);
cout<<q.size()<<endl;

输出:

复制代码
2

3.4 empty()

empty()判断队列是否为空,如果队列为空返回true

复制代码
queue<int>q;
cout<<q.empty()<<endl;
q.push(1);
q.push(2);
cout<<q.empty()<<endl;

输出:

复制代码
1
0

3.5 front()

front()返回队首元素

复制代码
queue<int>q;
q.push(1);
q.push(2);
q.push(3);
cout<<q.front()<<endl;
q.pop();
cout<<q.front()<<endl;

输出:

复制代码
1
2

3.6 back()

back()返回队尾元素

复制代码
queue<int>q;
q.push(1);
q.push(2);
cout<<q.back()<<endl;

输出:

复制代码
2

4.stack的头文件

复制代码
#include<stack>

5.stack的定义

复制代码
stack<类型名>变量名;

类型可以是int,double等基本数据类型,也可以是自定义的结构体,也可以是STL容器。

6.stack的常用函数

6.1 push()

push()将元素压入栈中

复制代码
stack<int>st;
st.push(1);
st.push(2);

6.2 top()

因为栈是一种先进后出的数据结构,我们只能访问栈顶元素

复制代码
stack<int>st;
st.push(1);
st.push(2);
cout<<st.top()<<endl;

输出:

复制代码
2

6.3 pop()

pop()用来弹出栈顶元素

复制代码
stack<int>st;
st.push(1);
st.push(2);
cout<<st.top()<<endl;
st.pop();
cout<<st.top()<<endl;

输出:

复制代码
2
1

6.4 size()

size()返回栈中元素个数

复制代码
stack<int>st;
st.push(1);
st.push(2);
st.push(3);
cout<<st.size()<<endl;

输出:

复制代码
3

6.6 empty()

empty()用来判断栈是否为空,为空返回1,表示true;不为空返回0,表示false

复制代码
stack<int>st;
cout<<st.empty()<<endl;
st.push(1);
st.push(2);
cout<<st.empty()<<endl;

输出:

复制代码
1
0
相关推荐
Bona Sun1 小时前
单片机手搓掌上游戏机(二十三)—esp32运行简单街机模拟器软硬件准备
c语言·c++·单片机
@小码农2 小时前
2025年北京海淀区中小学生信息学竞赛第二赛段C++真题
开发语言·数据结构·c++·算法
sulikey2 小时前
C++模板初阶详解:从函数模板到类模板的全面解析
开发语言·c++·模板·函数模板·类模板
0 0 02 小时前
CCF-CSP第39次认证第三题——HTTP 头信息(HPACK)【C++】
开发语言·c++·算法
合方圆~小文2 小时前
不同画面,三个镜头实时监控拍摄方案
数据结构·数据库·人工智能
Q8762239652 小时前
西门子S7 - 1200控制5轴伺服程序与维纶触摸屏画面案例分享
数据结构
汉克老师2 小时前
2023年海淀区中小学信息学竞赛复赛(小学组试题第二题 回文时间 (time))
c++·算法·北京海淀中小学信息竞赛·模拟法
代码雕刻家2 小时前
1.9.课设实验-数据结构-图-校园跑最短路径
c语言·数据结构·算法·图论
.YM.Z3 小时前
【数据结构】:排序(二)——归并与计数排序详解
数据结构·算法·排序
武帝为此3 小时前
【数据结构之树状数组】
数据结构·算法