5.2用队列实现栈(LC225-E)

news2025/1/18 14:04:01

算法:

其实这道题不用像上一道题一样,用两个队列实现栈。

由于队列的数据结构特性。用一个队列就可实现栈。

难点还是在出队的时候:

  • 比如队列=[1,2,3],要模拟一个栈
  • 入栈就是直接append(其实就是C++中的push)
  • 出栈时应该先出3,但是队列先出1
  • 此时可以先把1取出来,再加入队列,即[2,3,1]
  • 再把2取出来,再加入队列,即[3,1,2]
  • 这个时候再取出队首3,也就模拟了出栈操作。

总结:

只要将队列首部的元素(除了最后一个元素外) 重新添加到队列尾部,此时再去弹出元素就是栈的顺序了。

为什么用栈实现队列的时候要用两个栈?

因为栈底部是密封的,只有上面敞口;而队列前后都敞口。

所以队列可以实现“先从队首把1取出来,再加入队列”的操作,而栈要取数只能从最上面敞口的地方取。

Top算法:

对于 Python 中的序列类型(如列表、元组、字符串等),可以使用负数索引来访问元素。负数索引表示从序列的末尾开始计数,-1 表示最后一个元素,-2 表示倒数第二个元素,依此类推。

可以使用负数索引来访问队列的最后一个元素,如self.que[-1]。

调试过程:

 Python普通的Queue或SimpleQueue没有类似于peek的功能
        也无法用索引访问,在实现top的时候较为困难。

        用list可以,但是在使用pop(0)的时候时间复杂度为O(n)
        因此这里使用双向队列,我们保证只执行popleft()和append(),因为deque可以用索引访问,可以实现和peek相似的功能

class MyStack:
    def __init__(self):
        self.que = deque()
    def push(self, x: int) -> None:
        self.que.append(x)
    def pop(self) -> int:
        if self.empty():
            return None
        else:
            for i in range(len(self.que)-1):
                self.que.append(self.que.pop())
            return self.que.pop()
    def top(self) -> int:
        if self.empty():
            return None
        else:
           return self.que[-1]
    def empty(self) -> bool:
        return self.que



# Your MyStack object will be instantiated and called as such:
# obj = MyStack()
# obj.push(x)
# param_2 = obj.pop()
# param_3 = obj.top()
# param_4 = obj.empty()

原因:

因为我的 `empty` 方法返回的是一个 `deque` 对象,而预期的返回类型是布尔值。

为了解决这个问题,可以将 `empty` 方法中的返回语句修改为 `return not self.que`。这样,如果队列为空,返回 `True`,否则返回 `False`

正确代码:

class MyStack:
    def __init__(self):
        self.que = deque()
    def push(self, x: int) -> None:
        self.que.append(x)
    def pop(self) -> int:
        if self.empty():
            return None
        else:
            for i in range(len(self.que)-1):
                self.que.append(self.que.pop())
            return self.que.pop()
    def top(self) -> int:
        if self.empty():
            return None
        else:
           return self.que[-1]
    def empty(self) -> bool:
        return not self.que

优化:

Top里面的que[-1]实际上用到了栈,因为直接获取了que的末尾元素。

其实可以类似pop函数,将队列首部的元素(除了最后一个元素外) 重新添加到队列尾部,此时再去弹出的元素就是栈的首了

不过要把这个“栈首”再加回队列里面,因为top不改变栈。

  • 比如队列=[1,2,3],要模拟一个栈
  • 出栈时应该先出3,但是队列先出1
  • 此时可以先把1取出来,再加入队列,即[2,3,1]
  • 再把2取出来,再加入队列,即[3,1,2]
  • 这个时候再取出队首3,也就是top,将其弹出
  • 再把这个3加入队列,即[1,2,3]。其实没有改变栈的内容。
class MyStack:
    def __init__(self):
        self.que = deque()
    def push(self, x: int) -> None:
        self.que.append(x)
    def pop(self) -> int:
        if self.empty():
            return None
        else:
            for i in range(len(self.que)-1):
                self.que.append(self.que.pop())
            return self.que.pop()
    def top(self) -> int:
        if self.empty():
            return None
        else:
            for i in range(len(self.que)-1):
                self.que.append(self.que.pop())
            temp = self.que.pop()
            self.que.append(temp)
            return temp
           
    def empty(self) -> bool:
        return not self.que



# Your MyStack object will be instantiated and called as such:
# obj = MyStack()
# obj.push(x)
# param_2 = obj.pop()
# param_3 = obj.top()
# param_4 = obj.empty()

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

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

相关文章

creating server tcp listening socket 127.0.0.1:6379: bind No error

window下启动redis服务报错: creating server tcp listening socket 127.0.0.1:6379: bind No error 解决方案如下按顺序输入如下命令即可连接成功 redis-cli.exeshutdownexit运行:redis-server.exe redis.windows.conf shutdown出现以下错误&#xff…

数据结构之队的实现

𝙉𝙞𝙘𝙚!!👏🏻‧✧̣̥̇‧✦👏🏻‧✧̣̥̇‧✦ 👏🏻‧✧̣̥̇:Solitary-walk ⸝⋆ ━━━┓ - 个性标签 - :来于“云”的“羽球人”。…

变压器那些事

电磁感应 电磁感应效应是指当一个导体或线圈处于变化的磁场中时,会在导体或线圈中产生感应电动势或感应电流的现象。 根据法拉第电磁感应定律,当一个导体或线圈被置于变化的磁场中时,通过该导体或线圈的磁通量会发生变化,从而在…

零代码复现-TCGA联合GEO免疫基因结合代谢基因生信套路(一)

经过一段时间的积累,搭建的分析平台已经日渐进入稳定的状态,很多粉丝也在和我们反馈,让我们出一下零代码生信套路课。 小编找了很久,发现某某机构出的TCGA联合GEO 免疫基因代谢基因的生信套路,该套路应用常见相对来说…

【音视频 | opus】opus编码的Ogg封装文件详解

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 🤣本文内容🤣&a…

【SpringCloud Alibaba -- Nacos】Linux 搭建 Nacos 集群

搭建 Nacos 集群 架构 centos安装docker https://docs.docker.com/engine/install/centos/ 详细配置过程 MySql8 mysql数据库配置 数据库脚本 nacos/conf/nacos-mysql.sql Nacos2 application.properties 修改为mysql spring.datasource.platformmysqldb.num1 db.url…

【算法挑战】字符的最短距离(含解析、源码)

821.字符的最短距离 https://leetcode-cn.com/problems/shortest-distance-to-a-character/ 821.字符的最短距离 题目描述解法 1:中心扩展法 思路复杂度分析代码 (JS/C) 解法 2:空间换时间 思路复杂度分析代码 (JS/C) 解法 3:贪心 思路复杂…

阿里大佬:DDD 领域层,该如何设计?

说在前面 在40岁老架构师 尼恩的读者交流群(50)中,最近有小伙伴拿到了一线互联网企业如阿里、滴滴、极兔、有赞、希音、百度、网易、美团的面试资格,遇到很多很重要的面试题: 谈谈你的DDD落地经验? 谈谈你对DDD的理解&#xff1f…

C语言 程序环境 编译和链接

目录 1.程序的翻译环境和执行环境 2.详解C语言程序的编译和链接 2.1翻译环镜 2.2翻译的几个阶段 2.2.1预编译 2.2.2编译 词法分析 符号汇总 2.2.3汇编 生成符号表 2.3链接 1.合并段表 2.合并符号表和重定位 2.4运行环境 1.程序的翻译环境和执行环境 在ANSI C的任…

【网络协议】聊聊DNS协议如何域名解析和负载均衡

DNS 服务器 我们知道如果使用IP地址进行访问网站,很难进行记忆,所以DNS的作用是将域名转换成对应的IP地址。如果全世界都使用同一台DNS服务器,那么DNS服务器本身需要保证服务的高可用、高性能,以及分布式等。最好的方式就是分层。…

日语动词三分类

所有的动词原形都是由う段结尾 50音图 一类动词 一类动词又称五段动词(う段动词) 1.结尾是う段非る的动词 ます形规律:う段 > 同行的い段ます 日文平假名ます形中文書くかく書きます写探すさがす探します寻找勝つかつ勝ちます胜利遊ぶ…

电脑报错找不到msvcp120dll,无法继续执行代码,怎么修复?

在运行电脑软件时,出现msvcp120.dll丢失,我深知大家在遇到这种电脑问题时所感受到的无助和焦虑。今天,我就来为大家分享一下关于msvcp120.dll文件缺失的4个一键解决方法,希望能帮助到大家。 首先,我们要明确什么是msv…

SecoClient连接报错:接收返回码超时

话接上回,SecoClient能打开了,但是出现了连接时的错误 这次针对接收返回码超时进行解决。 参考连接: https://www.cnblogs.com/Crazy-Liu/p/14700121.html https://blog.csdn.net/lnigluan511513/article/details/1280683581、正常我们进入…

【JVM】双亲委派机制、打破双亲委派机制

🐌个人主页: 🐌 叶落闲庭 💨我的专栏:💨 c语言 数据结构 javaEE 操作系统 Redis 石可破也,而不可夺坚;丹可磨也,而不可夺赤。 JVM 一、双亲委派机制1.1 双亲委派的作用1.…

Jetpack:028-Jetpack中的Card

文章目录 1. 概念介绍2. 使用方法2.1 主要类型2.2 其它类型 3. 示例代码4. 内容总结 我们在上一章回中介绍了Jetpack中Switch相关的内容,本章回中 主要介绍Card。闲话休提,让我们一起Talk Android Jetpack吧! 1. 概念介绍 我们在本章回中介…

linux的shell script判断用户输入的字符串,判断主机端口开通情况

判断输入的字符串是否是hello 图一运行报错 检查发下,elif 判断里面少个引号,哎,现在小白到了,一看就会,一写就错的时候了,好像现在案例比较简单,行数较少。 案例二 if 结合test 判断主机端…

企业电脑屏幕监控有哪些?如何实现电脑屏幕监控

企业电脑屏幕监控有哪些?如何实现电脑屏幕监控 下载使用安企神电脑屏幕监控软件 企业电脑屏幕监控是一种监测和记录员工在工作时间内在他们的计算机上执行的活动的技术。这种监控可以有多种目的,包括确保员工的生产力、确保数据安全性,或满…

CCLINK IEFB总线转ETHERNET/IP网络的协议网关使欧姆龙和三菱的数据互通的简单配置方法

想要实现CCLINK IEFB总线和ETHERNET/IP网络的数据互通。 捷米JM-EIP-CCLKIE是一款ETHERNET/IP从站功能的通讯网关,该产品主要功能是实现CCLINK IEFB总线和ETHERNET/IP网络的数据互通。本网关连接到ETHERNET/IP总线和CCLINK IEFB总线上都可以做为从站使用。网关分别…

静态链表的定义与实现(数据结构与算法)

1. 静态链表 用数组的方式实现的链表 单链表: 各个结点在内存中星罗棋布、散落天涯 静态链表:分配一整片连续的内存空间, 各个结点集中安置。 1.1 静态链表的优点 不需要像动态链表那样频繁地进行内存分配和释放,可以节省内存…

产品手册应该如何组织内容,以便用户能够快速找到所需信息?

产品手册应该如何组织内容,以便用户能够快速找到所需信息?这是一个关乎用户体验和产品文档效力的重要问题。当用户需要了解产品的功能、操作指南或故障排除时,他们希望能够轻松地找到准确、清晰的信息,而不是在冗长的手册中迷失方…