[C++随笔录] stack queue使用

news2024/11/15 15:41:58

stack && queue使用

  • stack
  • queue
  • 题目训练

stack

栈的特点是 先进后出(first in last out)

我们可以看出, stack的接口相比 vector/string/list 的接口少的太多了

  1. 构造函数 && 容器适配器
  • 容器适配器的含义:
    首先, 适配器 — — 用户传数据进来, 我们用合适的容器来进行管理
    其次, 容器 — — 容器要符合类型的要求. 比如堆要求用下标来访问数据, 那么我们适配的容器就应该是vector, 而不应该是list
    总结下来就是, 容器适配器是 外壳用容器封装, 数据由容器来进行管理
  1. 不支持下标访问数据, 不能进行遍历.
    只能通过不断的 pop 来进行访问数据
int main()
{
	stack<int> st;
	st.push(1);
	st.push(5);
	st.push(9);
	st.push(8);
	st.push(6);
	st.push(90);

	cout << "size->" << st.size() << endl;

	cout << "出数据->";
	while (!st.empty())
	{
		cout << st.top() << " ";
		st.pop();
	}
	cout << endl;

	return 0;
}

运行结果:

size->6
出数据->90 6 8 9 5 1

栈的知识也就这么多, 下面进入queue

queue

队列的特点是 先进先出 (first in first out)

跟stack很相似, 但是队列不仅有队头也有队尾, 而stack只有栈顶

  1. 我们发现, queue也使用的是 容器适配器
  2. 跟stack一样, 不支持下标访问数据, 不能进行遍历.
    只能通过不断的 pop 来进行访问数据
int main()
{
	queue<int> q;
	q.push(1);
	q.push(5);
	q.push(9);
	q.push(8);
	q.push(6);
	q.push(90);

	cout << "size->" << q.size() << endl;

	cout << "出数据->";
	while (!q.empty())
	{
		cout << q.front() << " ";
		q.pop();
	}
	cout << endl;

	return 0;
}

运行结果:

size->6
出数据->1 5 9 8 6 90

题目训练

  1. 最小栈



首先, 先想到的是定义一个全局变量 min, 在每次push 和 pop的时候更新一下min, 然后返回min就行了.
这么做是真的没问题吗? 看一下下面的例子:
push: 6, 5, 4, 3, pop两次
此时当前栈的最小值应该是5, 但是按照我们的想法, min应该是3才对
上面的那个想法不能很好地控制栈空间的变化

其实, 我们可以用两个栈来做: 一个负责正常工作, 一个负责记录当前栈的最小值

解题代码:

class MinStack {
public:

    void push(int val) 
    {
        st.push(val);
        // min_st进数据: 1. 首元素, 2.进入数据的元素 <= min_st的栈顶元素
        if(min_st.size() == 0 || val <= min_st.top())
        {
            min_st.push(val);
        }
    }
    
    void pop() 
    {
        if(min_st.top() == st.top())
        {
            min_st.pop();
        }
        st.pop();
    }
    
    int top() 
    {
        return st.top();
    }
    
    int getMin() 
    {
        return min_st.top();
    }

private:
    stack<int> st;
    stack<int> min_st;
};
  1. 栈的压入, 弹出序列

    不绕弯子了: 本题属于 模拟题, 模拟压栈,出栈的顺序来做的. 由此需要一个辅助栈来进行, 最后判断辅助栈是否为空就知道答案了!

思路:

  1. 不管什么, 先进栈 st
  2. 再判断栈顶元素是否和出栈数组的当前值相同
    1. 不相同, 什么事情也不用做, 继续入栈
    2. 相同, st出栈, 出栈数组向前挪动数据, 直至和栈顶元素不相同
  3. 结果: 看st是否为空
    1. 为空, 说明按照入栈, 出栈的顺序走了一遍, 说明逻辑是通的
    2. 不为空, 说明中间出现了问题, 说明逻辑是错误的

解题代码:

bool IsPopOrder(vector<int>& pushV, vector<int>& popV) 
{
   stack<int> st; // 辅助栈
   int pushi = 0; // 控制入栈数组
   int popi = 0;  // 控制出栈数组

   // 当没数据可入了, 说明入栈结束
   while(pushi < pushV.size())
   {
       // 先入栈
       st.push(pushV[pushi]);
       pushi++;

       // 防止st栈为空
       while(st.size() && st.top() == popV[popi])
       {
           st.pop();
           popi++;
       }

   }

   return st.empty();
}

2、知而不行,只是未知。
语出明·王守仁《传习录》。学了知识,而不实践,这等于没有学到知识一样。

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

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

相关文章

MMDet初尝试:以官方文档为例,训练模型

使用前配置 按照官方文档配置环境&#xff1a;https://mmdetection.readthedocs.io/zh_CN/3.x/get_started.html 安装conda/Miniconda 创建并激活一个 conda 环境 conda create --name openmmlab python3.8 -y conda activate openmmlab安装PyTorch&#xff08;GPU平台&#…

C++ 多态:(使用Shape类层次结构的多态性的屏幕管理器)开发一个基本图形软件包

基于上篇C 多态&#xff1a;Shape类层次结构https://mp.csdn.net/mp_blog/creation/editor/133175074 【问题描述】 使用C 多态&#xff1a;Shape类层次结构中实现的Shape类层次。仅限于二维形状&#xff0c;如正方形&#xff0c;长方形、三角形和圆。和用户进行交互&#xff…

计算机操作系统 (王道考研)笔记(三)文件

目录 1 文件1.1 内存映射文件1.1.1 定义1.1.2 传统文件访问方式1.1.3 内存映射文件访问方式 1.2 文件管理1.3 文件的逻辑结构1.4 文件目录1.5 文件物理结构&#xff08;文件分配方式&#xff09;1.6文件的逻辑结构和物理结构 2 I/O3 缓冲区&#xff0c;磁盘 1 文件 1.1 内存映…

第二证券:北证50是什么意思?

随着中国资本市场的不断发展&#xff0c;投资者开始关注市场指数。北证50指数是其中一个备受关注的指数。那么&#xff0c;北证50究竟是什么意思呢&#xff1f;本文将从定义、历史、构成股票等多个角度分析北证50指数&#xff0c;帮助读者全面了解该指数。 1.定义 北证50指数…

基于Web安全的Python编程(1)

目录 一、http协议基础知识介绍 1、http协议分类 2、请求方法 3、什么是URL 4、请求头 5、响应状态码 二、常用Python库、函数、操作 三、http常用请求方法 1、不带参请求 2、带参数请求&#xff08;get和post存在细微区别&#xff09; 四、http响应属性获取 1、获取…

TikTok营销成功秘籍:ROI指标的黄金法则

在当今数字营销领域&#xff0c;TikTok已经崭露头角&#xff0c;成为了品牌和营销者们争相追逐的热门平台。 然而&#xff0c;要在TikTok上取得成功&#xff0c;不仅需要创意和内容&#xff0c;还需要精确的ROI&#xff08;投资回报率&#xff09;指标来衡量和优化你的营销策略…

【python入门篇】列表简介及操作(2)

列表是什么&#xff1f; 列表是由一系列按特定顺序排列的元素组成。你可以创建包含字母表中的所有字母、数字 0~9 或所有家庭成员的列表&#xff1b;也可以将任何东西加入列表中&#xff0c;其中的元素之间可以没有任何关系。列表通常包含多个元素&#xff0c;因此给列表指定一…

图片转RGB数组格式

0 Preface/Foreword 嵌入式开发中&#xff0c;想要在LCD屏幕中显示任意照片&#xff0c;该如何操作&#xff1f; 根据LCD的大小确定把照片进行缩放&#xff1b;比如LCD的规格为&#xff1a;360 RGB* 360&#xff0c; 原始照片的大小为&#xff1a;1000RGB*1000&#xff0c;那…

FlashAttention2原理解析以及面向AIGC的加速实践

FlashAttention-2提出后&#xff0c;便得到了大量关注。本文将具体讲述FlashAttention-2的前世今生&#xff0c;包括FlashAttention1&2的原理解析、加速效果比较以及面向AIGC的加速实践&#xff0c;在这里将相关内容与大家分享&#xff5e; 引言 将 Transformers 扩展到更长…

文心一言 VS 讯飞星火 VS chatgpt (102)-- 算法导论9.3 8题

八、用go语言&#xff0c;设 X[1…n]和 Y[1…n]为两个数组&#xff0c;每个都包含n个有序的元素。请设计一个 O(lgn)时间的算法来找出数组 X和Y中所有 2n 个元素的中位数。 文心一言&#xff1a; 要在 O(lgn) 时间内找出两个有序数组 X 和 Y 中所有元素的中位数&#xff0c;可…

vue最新前端面试题系列(1-5)

前言: 欢迎浏览和关注本专栏《 前端就业宝典 》, 不管是扭螺丝还是造火箭, 多学点知识总没错。 这个专栏是扭螺丝之上要造火箭级别的知识,会给前端工作学习的小伙伴带来意想不到的帮助。 文章目录 1,Vue 常用的修饰符都有哪些?事件修饰符表单修饰符2,$route和 $router的…

企业年报API的应用:从金融投资到市场研究

引言 在数字化时代&#xff0c;企业年报不再仅仅是一份财务报告&#xff0c;它们变成了宝贵的信息资源&#xff0c;可用于各种商业应用。企业年报API已经改变了金融投资和市场研究的方式&#xff0c;使得从中获取数据变得更加高效和灵活。本文将深入探讨企业年报API的应用&…

创建线程的4种方法

目录 一.前言 1.关于进程调度 (1)为什么要调度? (2)调度的真正对象 (3)调度的资源 2.线程 (1).线程的写法 (2)线程创建的方法 1.继承Thread (1)使用继承Thread,重写run的方式来创建线程 (2)继承Thread,使用匿名内部类 2.实现Runnable (1)使用实现Runnable,重写run…

基于SSM的网上药品售卖系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

衷心 祝愿

达之云衷心祝愿您&#xff0c;中秋国庆双节快乐&#xff0c;阖家幸福&#xff01;感谢您们一直以来对达之云的关注与支持。 双节来临之际&#xff0c;达之云发布全新产品——达之云CDP客户数据平台&#xff08;Dazdata CDP&#xff09;&#xff0c;致力于为中小企业提供互联网营…

【VUE复习·6】监视属性watch:用途、两种写法、简写、应用时注意事项(重点)、深度监视(重点)

总览 1.监视属性是用来干什么的&#xff1f; 2.监视属性的两种写法 3.应用时注意事项 4.深度监视 一、监视属性是用来干什么的&#xff1f; 1.用途 监视一个值&#xff08;可以是基本属性 data&#xff0c;或者是计算属性 computed&#xff09;是否被改变。如果此值被改变&…

品牌奖项+个人奖项双丰收,极智嘉全面展现自身硬核实力

最近&#xff0c;中国物流与采购联合会发布了2022年度科学技术奖获奖名单。在这份名单中&#xff0c;极智嘉与国药物流、南京医药、九州通医药以及多所高校合作&#xff0c;成功研发并应用了“面向医药流通的大规模机器人集群系统关键技术”。这项研究赢得了科学技术进步奖的一…

SpringCloud + SpringGateway 解决Get请求传参为特殊字符导致400无法通过网关转发的问题

title: “SpringCloud SpringGateway 解决Get请求传参为特殊字符导致400无法通过网关转发的问题” createTime: 2021-11-24T10:27:5708:00 updateTime: 2021-11-24T10:27:5708:00 draft: false author: “Atomicyo” tags: [“tomcat”] categories: [“java”] description: …

Win10检测和配置使用千兆网

注&#xff1a;一般只有比较旧的电脑才会是百兆网卡&#xff08;我的2019年笔记本dell灵越是百兆网卡瑞昱RTL810x/8139&#xff0c;离谱&#xff09;。 查看硬件是否为千兆网卡 cmd内执行如下&#xff08;100000000b100000kb100Mb&#xff0c;我这里显示的为百兆&#xff09;…

如何在不失去理智的情况下调试 TensorFlow 训练程序

一、说明 关于tensorflow的调试&#xff0c;是一个难啃的骨头&#xff0c;除了要有耐力&#xff0c;还需要方法&#xff1b;本文假设您是一个很有耐力的开发者&#xff0c;为您提供一些方法&#xff1b;这些方法也许不容易驾驭&#xff0c;但是依然强调您只要有耐力&#xff0c…