当前位置: 首页 > news >正文

Leetcode 946.验证栈序列

1.题目描述

给定 pushedpopped 两个序列,每个序列中的 值都不重复,只有当它们可能是在最初空栈上进行的推入 push 和弹出 pop 操作序列的结果时,返回 true;否则,返回 false


输入:pushed = [1,2,3,4,5], popped = [4,5,3,2,1]
输出:true
解释:我们可以按以下顺序执行:
push(1), push(2), push(3), push(4), pop() -> 4,
push(5), pop() -> 5, pop() -> 3, pop() -> 2, pop() -> 1


输入:pushed = [1,2,3,4,5], popped = [4,3,5,1,2]
输出:false
解释:1 不能在 2 之前弹出。


提示:

  • 1 <= pushed.length <= 1000
  • 0 <= pushed[i] <= 1000
  • pushed 的所有元素 互不相同
  • popped.length == pushed.length
  • poppedpushed 的一个排列

2.思路分析

2.1 栈模拟

对于题目给定的pushed和poped数组的如下性质:

  • 数组 pushed 中的元素互不相同;
  • 数组 popped 和数组 pushed 的长度相同;
  • 数组 popped 是数组 pushed 的一个排列。

根据上述性质,可以得出:

  • 栈内不会出现重复元素

  • 如果pushed 和 popped 是有效的栈操作序列,则经过所有的入栈和出栈操作之后,每个元素各

    入栈和出栈一次,栈为空。

遍历两个数组,模拟入栈和出栈操作,判断两个数组是否为有效的栈操作序列。

模拟入栈可以通过遍历pushed数组实现,由于只有栈顶的元素可以出栈,因此模拟出栈操作需要判

断栈顶元素是否与popped数组中当前元素相同(相同栈顶元素出栈)。

具体步骤:

  • 遍历数组 pushed,将 pushed 的每个元素依次入栈;

  • 每pushed 的元素入栈之后,如果栈不为空且栈顶元素与 popped 的当前元素相同,则将栈顶元

    素出栈,同时遍历数组 popped,直到栈为空或栈顶元素与 popped 的当前元素不同。

  • 遍历数组 pushed 结束之后,每个元素都按照数组 pushed 的顺序入栈一次。

  • 如果栈为空, 每个元素都按照数组popped的顺序出栈, 返回true

  • 如果栈不为空,每个元素都不能按照数组popped的顺序出栈, 返回false

举个栗子:pushed = [1,2,3,4,5], popped = [4,5,3,2,1]

  • 模拟入栈操作
    在这里插入图片描述

  • 模拟出栈

在这里插入图片描述

  • 遍历结束后

在这里插入图片描述

3.代码实现

class Solution:
    def validateStackSequences(self, pushed: List[int], popped: List[int]) -> bool:
        # 定义栈(初始化为空)以及指针(指向popped数组,初始化为0)
        stack, pi = [], 0
        # 遍历pushed数组
        for i in range(len(pushed)):
            # 模拟入栈 pushed数组元素入栈
            stack.append(pushed[i])
            # 模拟出栈,当栈存在且栈顶元素等于popped当前元素,出栈
            while stack and stack[-1] == popped[pi]:
                stack.pop()
                pi += 1
        # 遍历结束后, 栈为空返回true 反之false
        return not stack

复杂度分析

  • 时间复杂度:O(n),其中 n 是数组 pushed 和 popped 的长度。需要遍历数组 pushed 和 popped 各一次,判断两个数组是否为有效的栈操作序列。

  • 空间复杂度:O(n),其中 nn 是数组 pushed 和popped 的长度。空间复杂度主要取决于栈空间,栈内元素个数不超过 n。

相关文章:

  • CREO:利用CREO软件实现装配设计之四连杆机构设计案例应用(图文教程)之详细攻略
  • 基于数字孪生的智慧城市是如何发展的?
  • STL——list使用和模拟
  • 缓存怎么测试?
  • 智能控制理论及应用 王耀南等编著
  • 修改centos中Mysql( mariadb)数据默认存储位置
  • 神经网络编程教程入门课,人工神经网络编程内容
  • 零基础学Java有哪些必看书?推荐这5本
  • Python语句和循环
  • 阿里巴巴微服务核心手册:Spring Boot+Spring cloud+Dubbo
  • ssm基于微信小程序的社区老人健康管理服务系统的设计与实现毕业设计源码011513
  • opencv-python之位平面分解与数字水印
  • 技术分享 | 黑盒测试方法论—等价类
  • 医疗信息管理系统(HIS)——>业务介绍
  • 电脑截图怎么转换成文字?学会这个方法,轻松实现
  • canvas 高仿 Apple Watch 表盘
  • Flannel解读
  • iOS动画编程-View动画[ 1 ] 基础View动画
  • java2019面试题北京
  • Joomla 2.x, 3.x useful code cheatsheet
  • JSONP原理
  • macOS 中 shell 创建文件夹及文件并 VS Code 打开
  • node 版本过低
  • php面试题 汇集2
  • Python爬虫--- 1.3 BS4库的解析器
  • SegmentFault 社区上线小程序开发频道,助力小程序开发者生态
  • Traffic-Sign Detection and Classification in the Wild 论文笔记
  • TypeScript实现数据结构(一)栈,队列,链表
  • vue--为什么data属性必须是一个函数
  • 产品三维模型在线预览
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 更好理解的面向对象的Javascript 1 —— 动态类型和多态
  • 力扣(LeetCode)965
  • 融云开发漫谈:你是否了解Go语言并发编程的第一要义?
  • 首页查询功能的一次实现过程
  • 我的zsh配置, 2019最新方案
  • 一些css基础学习笔记
  • 再谈express与koa的对比
  • postgresql行列转换函数
  • python最赚钱的4个方向,你最心动的是哪个?
  • 第二十章:异步和文件I/O.(二十三)
  • 正则表达式-基础知识Review
  • #162 (Div. 2)
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (附源码)ssm捐赠救助系统 毕业设计 060945
  • (官网安装) 基于CentOS 7安装MangoDB和MangoDB Shell
  • (亲测有效)解决windows11无法使用1500000波特率的问题
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (四)c52学习之旅-流水LED灯
  • (原創) 如何讓IE7按第二次Ctrl + Tab時,回到原來的索引標籤? (Web) (IE) (OS) (Windows)...
  • (正则)提取页面里的img标签
  • (转)IOS中获取各种文件的目录路径的方法
  • *ST京蓝入股力合节能 着力绿色智慧城市服务
  • .NET Reactor简单使用教程
  • .net 设置默认首页