C++中的STL——stack类的基本使用

目录

stack类介绍

stack类定义

stack类常见构造函数

stack数据操作

empty()函数

size()函数

top()函数

push()函数

pop()函数

swap()函数


stack类介绍

  1. stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。
  2. stack是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部(即栈顶)被压入和弹出。
  3. stack的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类
  4. 标准容器vector、deque、list均符合这些需求,默认情况下,如果没有为stack指定特定的底层容器,默认情况下使用deque。

stack类定义

template <class T, class Container = deque<T> > class stack;

stack类为类模板,所以在使用时需要带上类型表示一个具体的类,例如数据类型为int类型的stack使用时需要写为stack<int>

stack类常见构造函数

构造函数

函数原型

无参构造函数

explicit stack (const container_type& ctnr = container_type());

📌

上面表格中的前三个构造函数均含有自定义空间配置器并带有缺省值,目前只使用默认即可

📌

使用stack类需要包含头文件<stack>

示例代码:

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;st.push(1);st.push(2);st.push(3);st.push(4);st.push(5);//打印栈while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;return 0;
}
输出结果:
5 4 3 2 1

stack数据操作

函数

功能

empty()

判断调用对象栈是否为空栈

size()

获取调用对象栈中的有效数据个数

top()

获取调用对象栈中的栈顶元素

push()

向调用对象栈顶插入元素

pop()

弹出调用对象栈顶元素

swap()

交换调用对象栈和指定栈

empty()函数

使用empty()函数可以判断调用对象栈是否为空栈

函数

函数原型

empty()

bool empty() const;

示例代码:

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;stack<int> st1;st.push(1);st.push(2);st.push(3);st.push(4);st.push(5);cout << "st: " << st.empty() << endl;cout << "st1: " << st1.empty() << endl;return 0;
}
输出结果:
st: 0
st1: 1

size()函数

使用size()函数可以获取调用对象栈中的有效数据个数

函数

函数原型

size()

size_type size() const;

示例代码:

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;stack<int> st1;st.push(1);st.push(2);st.push(3);st.push(4);st.push(5);cout << "st: " << st.size() << endl;cout << "st1: " << st1.size() << endl;return 0;
}
输出结果:
st: 5
st1: 0

top()函数

使用top()函数可以获取调用对象栈中的栈顶元素

函数

函数原型

top()

value_type& top();

const value_type& top() const;

📌

注意,如果栈为空时取栈内元素将会出现断言错误

示例代码:

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;stack<int> st1;st.push(1);st.push(2);st.push(3);st.push(4);st.push(5);cout << "st: " << st.top() << endl;// 断言错误//cout << "st1: " << st1.top() << endl;return 0;
}
输出结果:
5

push()函数

使用push()函数可以向调用对象栈内插入数据

函数

函数原型

push()

void push (const value_type& val);

示例代码:

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;st.push(1);st.push(2);st.push(3);st.push(4);st.push(5);//打印栈while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;return 0;
}
输出结果:
5 4 3 2 1

pop()函数

使用pop()函数可以弹出调用对象栈的栈顶元素

函数

函数原型

pop()

void pop();

📌

注意,当栈中没有元素时,调用pop()函数会出现断言错误

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;stack<int> st1;st.push(1);st.push(2);st.push(3);cout << st.top() << " ";st.pop();st.push(4);st.push(5);//打印栈while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;// 断言错误//cout << "st1: " << st1.top() << endl;return 0;
}
输出结果:
3 5 4 2 1

swap()函数

使用swap()函数可以交换调用对象栈和指定对象栈

函数

函数原型

swap()

void swap (stack& x);

示例代码:

#include <iostream>
#include <stack>
using namespace std;int main()
{stack<int> st;stack<int> st1;st.push(1);st.push(1);st.push(1);st.push(1);st.push(1);st1.push(2);st1.push(2);st1.push(2);st1.push(2);st1.push(2);cout << "交换前:" << endl;//打印栈while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;//打印栈while (!st1.empty()){cout << st1.top() << " ";st1.pop();}cout << endl;// 注意打印已经使栈为空,需要重新插入元素st.push(1);st.push(1);st.push(1);st.push(1);st.push(1);st1.push(2);st1.push(2);st1.push(2);st1.push(2);st1.push(2);st.swap(st1);cout << "交换后:" << endl;//打印栈while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;//打印栈while (!st1.empty()){cout << st1.top() << " ";st1.pop();}cout << endl;return 0;
}
交换前:
1 1 1 1 1
2 2 2 2 2
交换后:
2 2 2 2 2
1 1 1 1 1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/827139.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Leetcode】string类刷题

&#x1f525;个人主页&#xff1a;Quitecoder &#x1f525;专栏&#xff1a;Leetcode刷题 目录 1.仅反转字母2.字符串中第一个唯一字符3.验证回文串4.字符串相加5.反转字符串I I6.反转字符串中的单词III7.字符串相乘8.把字符串转换为整数 1.仅反转字母 题目链接&#xff1a;…

一篇文章带您了解面向对象(java)

1.简单理解面向过程编程和面向对象编程 面向过程编程&#xff1a;开发一个一个的方法&#xff0c;有数据需要处理&#xff0c;我们就可以调用方法来处理。 package com.web.quictstart;public class demo1 {public static void main(String[] args) {totalScore("张三&q…

mac上VMware fusion net模式无法正常使用的问题

更新时间&#xff1a;2024年04月22日21:39:04 1. 问题 环境&#xff1a; intel芯片的macbook pro VMware fusion 13.5.1 无法将“Ethernet0”连接到虚拟网络“/dev/vmnet8”。在这里显示这个之后&#xff0c;应该是vmnet8的网段发生了冲突&#xff0c;所以导致无法正常使用…

前端开发攻略---拖动归类,将元素拖拽到相应位置

1、演示 2、代码 <!DOCTYPE html><html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content"widthdevice-…

2024年Q1季度平板电视行业线上市场销售数据分析

Q1季度平板电视线上市场表现不如预期。 根据鲸参谋数据显示&#xff0c;2024年1月至3月线上电商平台&#xff08;京东天猫淘宝&#xff09;平板电视累计销量约360万件&#xff0c;环比下降12%&#xff0c;同比下降30%&#xff1b;累计销售额约99亿元&#xff0c;环比下降28%&a…

学习STM32第十七天

备份域详解 一、简介 在参考手册的电源控制章节&#xff0c;提到了备份域&#xff0c;BKPR是在RTC外设中用到&#xff0c;包含20个备份数据寄存器&#xff08;80字节&#xff09;&#xff0c;备份域包括4KB的备份SRAM&#xff0c;以32位、16位或8位模式寻址&#xff0c;在VBAT…

C++初阶学习第二弹——C++入门(下)

C入门&#xff08;上&#xff09;&#xff1a;C初阶学习第一弹——C入门&#xff08;上&#xff09;-CSDN博客 目录 一、引用 1.1 引用的实质 1.2 引用的用法 二、函数重载 三、内敛函数 四、auto关键字 五、总结 前言&#xff1a; 在上面一章我们已经讲解了C的一些基本…

Vue2进阶之Vue2高级用法

Vue2高级用法 mixin示例一示例二 plugin插件自定义指令vue-element-admin slot插槽filter过滤器 mixin 示例一 App.vue <template><div id"app"></div> </template><script> const mixin2{created(){console.log("mixin creat…

【Java网络编程】TCP通信(Socket 与 ServerSocket)和UDP通信的三种数据传输方式

目录 1、TCP通信 1.1、Socket 和 ServerSocket 1.3、TCP通信示例 2、UDP的三种通信&#xff08;数据传输&#xff09;方式 1、TCP通信 TCP通信协议是一种可靠的网络协议&#xff0c;它在通信的两端各建立一个Socket对象 通信之前要保证连接已经建立&#xff08;注意TCP是一…

【Interconnection Networks 互连网络】Torus 网络拓扑

1. Torus 网络拓扑2. Torus 网络拓扑结构References 1. Torus 网络拓扑 Torus 和 Mesh 网络拓扑&#xff0c;又可以称为 k-ary n-cubes&#xff0c;在规则的 n 维网格中包裹着 N k^n 个节点&#xff0c;每个维度都有 k 个节点&#xff0c;并且最近邻居之间有通道。k-ary n-c…

YOLOv9有效改进专栏汇总|未来更新卷积、主干、检测头注意力机制、特征融合方式等创新![2024/4/21]

​ 专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;助力高效涨点&#xff01;&#xff01;&#xff01; 专栏介绍 YOLOv9作为最新的YOLO系列模型&#xff0c;对于做目标检测的同学是必不可少的。本专栏将针对2024年最新推出的YOLOv9检测模型&#xff0…

《HCIP-openEuler实验指导手册》1.3Apache动态功能模块加载卸载练习

1.3.1 配置思路 mod_status 模块可以帮助管理员通过web界面监控Apache运行状态&#xff0c;通过LoadModule指令加载该模块&#xff0c;再配置相关权限&#xff0c;并开启ExtendedStatus后&#xff0c;即可使用该模块。 1.3.2 配置步骤 检查mod_status模块状态&#xff08;使…

net模块

建立TCP的链接 1 发送消息的服务 2 接收消息 2 建立http的链接让浏览器进行访问 import net from netconst html <h1>TCP</h1>const respinseHeaders [HTTP/1.1 200 OK,Content-Type:text/html,Content-Length: html.length,\r\n,html]const http net.create…

RK3568 学习笔记 : u-boot 通过 tftp 网络更新 u-boot自身

前言 开发板型号&#xff1a; 【正点原子】 的 RK3568 开发板 AtomPi-CA1 使用 虚拟机 ubuntu 20.04 收到单独 编译 RK3568 u-boot 使用 rockchip Linux 内核的设备树 【替换】 u-boot 下的 rk3568 开发板设备树文件&#xff0c;解决 u-boot 下千兆网卡设备能识别但是无法 Pi…

Spring(下)

接上篇&#xff0c;从第八个问题讲起 八.Spring工厂创建复杂对象 1.什么是复杂对象 简单对象就是可以直接new出来的&#xff0c;也就是直接调用构造方法创建 所以复杂对象就是不能直接通过调用构造方法创建。就比如JDBC中的Connection 2.三种方法 &#xff08;1&#xff…

【华为 ICT HCIA eNSP 习题汇总】——题目集18

1、SSH默认工作使用的TCP端口号是&#xff08;&#xff09;。 A、20 B、21 C、22 D、23 考点&#xff1a;①传输层 ②应用层 解析&#xff1a;&#xff08;C&#xff09; SSH为建立在应用层和传输层上的安全协议&#xff0c;是对TCP/IP协议的传输层以上的SSH会话流程进行加密的…

必应搜索广告与谷歌搜索广告对比那个更好?

搜索引擎广告作为企业获取潜在客户的重要渠道之一&#xff0c;其效果直接关系到营销策略的成功与否。两大搜索引擎巨头——谷歌&#xff08;Google&#xff09;和必应&#xff08;Bing&#xff09;各自提供了广告平台&#xff0c;即谷歌广告&#xff08;Google Ads&#xff09;…

【Web】2022DASCTF X SU 三月春季挑战赛 题解(全)

目录 ezpop calc upgdstore ezpop 瞪眼看链子 fin#__destruct -> what#__toString -> fin.run() -> crow#__invoke -> fin#__call -> mix.get_flag() exp <?php class crow {public $v1;public $v2;}class fin {public $f1; }class what {public $a; }…

力扣hot100(python解析)

文章目录 13. 合并区间14. 轮转数组 13. 合并区间 合并区间 数组 排序 思路&#xff1a; 代码&#xff1a; class Solution:def merge(self, intervals):result []if len(intervals) 0:return result # 区间集合为空直接返回intervals.sort() # 默认按照区间的左边界进…

z3求解器脚本(CTF-reverse必备)

CTF-reverse中有一类题目是通过约束方程求解变量的值&#xff0c;然后转化为对应的ASCII码&#xff0c;最终获得flag&#xff0c;约束方程以及要求解的未知数往往非常多&#xff0c;因此手算十分不现实&#xff0c;借助python中的z3模块可以很快完成求解&#xff01; 下面是某道…