JZ31. 栈的压入、弹出序列

news2025/1/16 17:50:25

文章目录

  • 1. 题目描述
  • 2. 解题思路
  • 3. 动图演示
  • 4. 代码实现


1. 题目描述

题目链接:31. 栈的压入、弹出序列

在这里插入图片描述

2. 解题思路

元素入栈指的是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;

元素出栈指的是从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

如下图所示,给定一个压入序列 pushed 和弹出序列 popped,则压入 / 弹出操作的顺序(即排列)是 唯一确定 的。

在这里插入图片描述

如下图所示,栈的数据操作具有 先入后出 的特性,因此某些弹出序列是无法实现的。

在这里插入图片描述

所以这道题考虑借用一个辅助栈 stack,模拟 压入 / 弹出操作的排列。根据是否模拟成功,即可得到结果。

  • 入栈操作: 按照压栈序列的顺序执行。

  • 出栈操作: 每次入栈后,循环判断 "栈顶元素 == 弹出序列的当前元素" 是否成立,将符合弹出序列顺序的栈顶元素全部弹出。

具体做法:

(1)初始化: 定义辅助栈 st,弹出序列的下标索引 i

(2)遍历压栈序列,元素入栈:循环出栈:若 st 的栈顶元素 == 弹出序列元素 popped[i],则执行出栈,然后再 i++

(3)返回值: 若 st 为空,则此弹出序列合法。

3. 动图演示

来看一个动图

在这里插入图片描述

4. 代码实现

代码示例

class Solution {
public:
    bool validateStackSequences(vector<int>& pushed, vector<int>& popped) {
        // 入栈和出栈的元素个数必须相同
        if (pushed.size() != popped.size())
            return false;

        stack<int> st;
        int i = 0;
        for (auto e : pushed) {
            st.push(e);
            while (!st.empty() && st.top() == popped[i]) {
                ++i;
                st.pop();
            }
        }
        // 如果栈不为空,说明不匹配
        return st.empty();
    }
};

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

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

相关文章

MySQL8.0高级篇(上)-架构与索引

文章目录一、MySQL环境安装与介绍1、MySQL安装1.1 安装前说明1.2 MySQL的Linux版安装1.3 MySQL登录1.4 字符集的相关操作1.5 字符集与比较规则(了解)1.6 请求到响应过程中字符集的变化1.7 SQL大小写规范1.8 sql_mode的合理设置2、MySQL的数据目录2.1 MySQL8的主要目录结构2.2 查…

Batch Normalization批量归一化

批量归一化&#xff08;batch normalization&#xff09;层&#xff0c;它能让较深的神经网络的训练变得更加容易。 对深层神经网络来说&#xff0c;即使输入数据已做标准化&#xff0c;训练中模型参数的更新依然很容易造成靠近输出层输出的剧烈变化。这种计算数值的不稳定性通…

前端基础_事件介绍

事件介绍 下面介绍一下浏览器在请求媒体数据、下载媒体数据、播放媒体数据一直到播放结束这一系列过程中&#xff0c;到底会触发哪些事件。  loadstart事件&#xff1a;浏览器开始请求媒介。  progress事件&#xff1a;浏览器正在获取媒介。  suspend事件&#xff1a;浏览器…

[附源码]计算机毕业设计Python大学生心理测评系统(程序+源码+LW文档)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

(15)目标检测算法之 YOLOv7应用解析

本文翻译自&#xff1a;https://github.com/WongKinYiu/yolov7 YOLOv7 2022年发布&#xff0c;论文链接&#xff1a;YOLOv7: Trainable bag-of-freebies sets new state-of-the-art for real-time object detectors 模型性能如下&#xff1a; 网页端可执行demo&#xff1a;Hu…

分支和循环语句(5)

目录 1、什么是语句&#xff1f; 2、分支语句&#xff08;选择结构&#xff09; 1、if 语句 1、if 语句的语法结构 2、悬空else 3、if书写形式的对比 4、练习 3、switch语句 1、语法形式 2、在switch语句中的 break 3、default子句 4、循环语句 1、while循环 1、…

10个Excel实用操作技巧分享,使用率超高,让你一学就会

学习和工作都能用到的Excel操作技巧&#xff0c;非常简单但是很实用&#xff0c;学会之后你会发现这些技巧的使用率超高&#xff0c;整理之后放在下面了&#xff0c;都是增加工作系效率的好帮手。1.冻结窗格 如果表格记录的数据比较多&#xff0c;我们可以使用【冻结窗格】&…

A. Parsa‘s Humongous Tree(树形DP + 贪心)

Problem - 1528A - Codeforces 两个玩家正在玩一个游戏。他们有一个整数1&#xff0c;2&#xff0c;...&#xff0c;n的排列组合&#xff08;排列组合是一个数组&#xff0c;其中从1到n的每个元素正好出现一次&#xff09;。这个排列组合没有按升序或降序排序&#xff08;即排列…

智能遥测终端机——微功耗设计的物联网网关

一、产品概述 智能遥测终端机是一款采用微功耗设计的物联网网关&#xff0c;采用内置电池组供电&#xff0c;支持对模拟量、开关量、RS485传感器采集并通过NB-IoT或4G通讯方式传输数据。智能遥测终端机支持参数远程升级、远程配置、蓝牙配置等&#xff0c;智能遥测终端机集成高…

1572_AURIX_TC275_SCU中的锁步以及芯片温度采集

全部学习汇总&#xff1a; GreyZhang/g_TC275: happy hacking for TC275! (github.com) 这个是锁步控制寄存器&#xff0c;其实是一个控制以及状态综合的寄存器。可以读取到现在的锁步设置状态&#xff0c;也可以进行锁步的使能。 这个寄存器跟上面这一个页一样&#xff0c;只是…

开发1-5年的Java程序员,该学习哪些知识实现涨薪30K?

工作已经8年有余&#xff0c;这8年里特别感谢技术管理人员的器重&#xff0c;以及同事的帮忙&#xff0c;学到了不少东西。这8年里走过一些弯路&#xff0c;也碰到一些难题&#xff0c;也受到过做为一名开发却经常为系统维护和发布当救火队员的苦恼。遂决定梳理一下自己所学的东…

11_逆向工程

MyBatis的一个主要的特点就是需要程序员自己编写SQL&#xff0c;那么如果表太多的话&#xff0c;难免会很麻烦&#xff0c;所以MyBatis官方提供了一个逆向工程&#xff0c;可以针对单表自动生成MyBatis执行所需要的代码&#xff08;包括mapper.xml&#xff0c;mapper.java&…

数据安全治理笔记

数据安全治理整理概述 数据安全治理不仅局限于组织内部&#xff0c;而是需要一个国家、行业组织、可言机构、企业和个人共同努力完成的课题。因此&#xff0c;应该分别重广义和狭义的角度看待数据安全治理。 广义地说&#xff1a;数据安全治理是在过数据安全战略的知道下&…

状态寄存器传送指令 —— 访问(读写)CPSR寄存器

CPSR寄存器控制着CPU的工作模式和运算状态&#xff0c;出于对CPSR的保护&#xff0c;不允许其他指令来访问CPSR寄存器。 因此&#xff0c;ARM提供了读写指令来操作CPSR寄存器&#xff0c;这两个指令是ARM特有的指令集&#xff0c;因为处理器之间存在一定差异&#xff0c;控制状…

在React中组件间过渡动画如何实现?

用transition 只能作一些最简单的动画,如果稍微复杂一点就做不出来了,这时候就可以用CSS3中的keyframes 像下面这样通过css实现动画: .show {animation:show-item 2s ease-in forwards; } .hide {animation:hide-item 2s ease-in forwards; }@keyframes hide-item{

STM32F051——USART

我在大二学32的时候曾经写过一篇博客&#xff0c;现在看了一个韩老师的专题课后再来完善一下32串口方面的知识。所有的知识都可在官方手册中找到&#xff0c;目前我认为学习一个新的芯片&#xff0c;最全最细的就是官方手册了&#xff0c;英文看不懂可以看中文的&#xff0c;不…

Nessus破解教程

Nessus 最新版破解教程0x01 Nessus 简介0x02 Nessus 下载0x03 Nessus 安装0x04 更新漏洞库0x05 Nessus 破解0x06 Nessus 使用0x07 注意事项参考文章0x01 Nessus 简介 Nessus 是目前全世界最多人使用的系统漏洞扫描与分析软件。总共有超过75,000个机构使用 Nessus 作为扫描该机…

跟着 gma 学 Python:矢量面文件的空间绘图

得益于 gdal 的强大功能&#xff0c;gma 继承了其对各类栅格/矢量&#xff08;目前支持超过80种矢量文件格式&#xff09;文件的读取支持&#xff0c;并在其基础上进行简化、优化等改造&#xff0c;以便其符合 gma 的整体建库逻辑。   本文基于 gma 定义的矢量读取逻辑和方式…

26 CPP运算符重载

#include <iostream>using namespace std;//非成员函数重载 - class Person { public:Person() {m_score 0;m_name.clear();}void show() {cout << m_name << " " << m_score << endl;}int m_score;string m_name; };//全局重载号 vo…

毕业设计 - 基于SSH码头船只出行及配套货柜码放 管理系统【源码 + 论文】

文章目录前言一、项目设计1. 模块设计2. 实现效果二、部分源码项目源码前言 今天学长向大家分享一个 java web设计项目: 基于SSH码头船只出行及配套货柜码放 管理系统 一、项目设计 1. 模块设计 对于码头日常管理来说&#xff0c;主要是码头船只的管理&#xff0c;码头信息的…