STL中stack的使用

目录

一、stack类介绍和使用

stack类介绍

stack类定义

stack类常见构造函数

stack数据操作

empty()函数

top() pop() 和 push() 函数 

size()函数

swap()函数


一、stack类介绍和使用

stack类介绍

1.stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。

2.stack是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部(即栈顶)被压入和弹出

3.stack的底层容器可以是任何标准的容器类模版或者一些其他特定的容器类,这些容器类应该支持一下操作:

·empty:判空操作

·back:获取尾部元素操作

·push_back:尾部插入元素操作

·pop_back:尾部删除元素操作

4.标准容器vector、deque、list均符合这些需求,默认情况下,如果没有为stack指定特定的底层容器,默认情况下使用deque

stack类定义

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

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

stack类常见构造函数

#include <iostream>
using namespace std;
#include <stack>
int main(){stack<int> st;st.push(1);st.push(3);st.push(1);st.push(4);while (!st.empty()) {cout << st.top() << " ";st.pop();}cout << endl;return 0;
}
//4 1 3 1 

stack数据操作

empty()函数

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

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

top() pop() 和 push() 函数 

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

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

 

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

注意:

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

2️⃣如果栈为空时取栈内元素将会出现断言错误

#include <iostream>
using namespace std;
#include <stack>
int main(){stack<int> st;st.push(4);st.push(1);st.push(3);st.push(1);while (!st.empty()) {cout << st.top() << " ";//取出栈顶元素st.pop();//弹出栈顶元素}cout << endl;return 0;
}

size()函数

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

 

#include <iostream>
using namespace std;
#include <stack>
int main(){stack<int> st;st.push(4);st.push(1);st.push(3);st.push(1);cout << "栈中数据个数为:" <<st.size() << endl;while (!st.empty()) {cout << st.top() << " ";//取出栈顶元素st.pop();//弹出栈顶元素}cout << endl;cout << "栈中数据个数为:" <<st.size() << endl;return 0;
}
输出结果:
栈中数据个数为:4
1 3 1 4 
栈中数据个数为:0

swap()函数

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

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

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

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

相关文章

Flutter 中的 IconTheme 小部件:全面指南

Flutter 中的 IconTheme 小部件&#xff1a;全面指南 Flutter 是一个功能丰富的 UI 开发框架&#xff0c;它允许开发者使用 Dart 语言来构建跨平台的移动、Web 和桌面应用。在 Flutter 的丰富组件库中&#xff0c;IconTheme 是一个用于设置应用中图标主题的小部件&#xff0c;…

Eclipse语言编程:深入探索与实战应用

Eclipse语言编程&#xff1a;深入探索与实战应用 在编程的世界里&#xff0c;Eclipse以其强大的功能和灵活的扩展性&#xff0c;赢得了广大开发者的青睐。而Eclipse语言编程&#xff0c;更是将这一平台的优势发挥得淋漓尽致。本文将从四个方面、五个方面、六个方面和七个方面&…

「动态规划」买卖股票的最佳时机含冷冻期

力扣原题链接&#xff0c;点击跳转。 给你一个整数数组prices&#xff0c;其中prices[i]表示第i天的股票价格。设计一个算法计算出最大利润。在满足以下约束条件下&#xff0c;你可以尽可能地完成更多的交易&#xff08;多次买卖一支股票&#xff09;&#xff1a;卖出股票后&a…

Python 关于字符串格式化

在Python中&#xff0c;字符串格式化有以下几种方法&#xff1a; 1.可以使用字符串的str.center(width), str.ljust(width), 和 str.rjust(width)方法来实现字符串的居中、左对齐和右对齐操作。 居中对齐&#xff1a; text "Python" centered_text text.center(10…

华为S5700交换机版本升级步骤

在用一台华为交换机。由于需要做目的镜像接口&#xff0c;在配置过程中超过一个双向流量观察口就会报错。从官方文档查到可以升级版本解决。记录一下升级过程。 首先确定设备型号S5700-28C-EI&#xff0c;版本&#xff1a; s5700ei-v100r005c01spc100。一定仔细阅读官方文档。明…

[python][whl]python模块python_geohash的whl文件所有版本下载地址汇总

Python使用Geohash实现 作为一名经验丰富的开发者&#xff0c;你将要教授一位刚入行的小白如何使用Python实现Geohash。Geohash是一种地理编码系统&#xff0c;将地球分成若干个矩形区域&#xff0c;并为每个矩形区域分配一个唯一的字符串编码。下面是实现这一任务的详细步骤&a…

springboot基本使用十一(自定义全局异常处理器)

例如&#xff1a;我们都知道在java中被除数不能为0&#xff0c;为0就会报by zero错误 RestController public class TestController {GetMapping("/ex")public Integer ex(){int a 10 / 0;return a;}} 打印结果&#xff1a; 如何将这个异常进行处理&#xff1f; 创…

rust 引用本地库

project | env /| component / # 库| src /| led.rslib.rs # 不能是 mod.rs&#xff0c;内容为 pub mod led;Cargo.toml... | abc /| abc / # 工程| src /| main.rsCargo.toml...库和普通工程是一样的&#xff0c;区别在于工程需要引用库 库的 Cargo.toml&#xff1a; [packa…

寺庙小程序-H5网页开发

大家好&#xff0c;我是程序员小孟。 现在有很多的产品或者工具都开始信息话了&#xff0c;寺庙或者佛教也需要小程序吗&#xff1f; 当然了&#xff01; 前面我们还开发了很多寺庙相关的小程序。 今天要介绍的是一款寺庙系统&#xff0c;该系统可以作为小程序、H5网页、安…

springboot实现文件上传功能,整合云服务

文章目录 这是springboot案例的,文件上传功能的拆分,本篇将带大家彻底了解文件上传功能,先从本地存储再到云存储,全网最详细版本,保证可以学会,可以了解文件上传功能的开发文件上传功能剖析进行书写一个小的文件上传文件上传的文件三要素首先表单提交的方式要是 post方式,第二个…

Leetcode 剑指 Offer II 080.组合

题目难度: 中等 原题链接 今天继续更新 Leetcode 的剑指 Offer&#xff08;专项突击版&#xff09;系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 给定两个整数 n 和 k&#xff0c;返回 1 … n 中所有可能的 k 个…

vue2+antv/x6实现er图

效果图 安装依赖 npm install antv/x6 --save 我目前的项目安装的版本是antv/x6 2.18.1 人狠话不多&#xff0c;直接上代码 <template><div class"er-graph-container"><!-- 画布容器 --><div ref"graphContainerRef" id"gr…

houdini编程语言:深入探索其复杂性与独特性

houdini编程语言&#xff1a;深入探索其复杂性与独特性 Houdini编程语言&#xff0c;作为一个富有创意和挑战性的领域&#xff0c;吸引了无数编程爱好者的目光。其独特的设计理念和复杂的语法结构&#xff0c;使得它成为了一个极具困惑度和爆发度的编程语言。本文将从四个方面…

国际荐酒师(香港)协会受邀出席广州意大利国庆晚宴

2024年5月30日&#xff0c;意大利驻广州总领事馆举办的2024年意大利国庆招待会及晚宴&#xff0c;庆祝意大利共和国成立。此次晚宴旨在促进中意两国之间的文化交流与合作。国际荐酒师&#xff08;香港&#xff09;协会受主办方邀请参与了这一重要活动。 国际荐酒师&#xff08;…

内核调度客制化利器:SCHED_EXT

一、前言 今年年初&#xff0c;宋宝华老师发表了一篇对2023年内核技术总结的文章《熠熠生辉 | 2023 年 Linux 内核十大技术革新功能》。有兴趣的伙伴可以点击蓝色字体链接回顾。 文章提及的10个技术中&#xff0c;与CPU任务调度器核心相关的内容&#xff0c;一共有两个&#xf…

Spring IoC 的实现机制

案例一&#xff1a; Spring 中的 IoC 的实现原理就是工厂模式加反射机制。我们先使用一个简单的案例理解一下&#xff1a; import java.lang.reflect.Constructor; import java.lang.reflect.InvocationTargetException;// 定义一个水果接口&#xff0c;包含吃的方法 public i…

Vue 3.4.5深度解析:从基础到高级,掌握Composition API与全局API精髓

一、基础函数&特性 1. setup() 函数 作用&#xff1a;setup() 是Vue 3引入的一个新的组件选项&#xff0c;用于定义组件的逻辑。它在组件初始化阶段被调用&#xff0c;替代了Vue 2中的data、methods等选项。特点&#xff1a; 接收props和context作为参数。返回的对象将被…

Spring:jackson-annotaions注解大全

文章目录 一、介绍二、JsonProperty三、JsonIgnore四、JsonInclude五、JsonFormat六、JsonCreator 和 JsonProperty (在构造函数中)七、JsonTypeName 和 JsonTypeInfo八、JsonIgnoreProperties九、JsonSerialize十、JsonDeserialize 一、介绍 jackson-annotations 是 Jackson …

痛心!2岁女童被从17楼推下坠亡,凶手疑是未成年

一起又一起的案件&#xff0c; 如同一部沉重的史诗&#xff0c; 无声地述说着一个共同的真理&#xff1a; 严惩恶魔&#xff0c;实则是在庇护着无数纯真的心灵&#xff0c;守护着更多的孩子。 因为每一起案件的背后&#xff0c;都隐藏着一个个令人心碎的故事。 01 近日&#xf…

错误发生在尝试创建一个基于有限元方法的功能空间时

问题&#xff1a; index cell.index(#直接使用从0开始的索引if0<1ndex<10: #正集流体 subdomains_x[cell,index(] 1 fem1 /usr/bin/python3.8 /home/wy/PycharmProjects/pythonProject2/fem1.pyUnknown ufl object type FiniteElementTraceback (aost recent call last)…