面试题:通过队列实现栈

news2025/1/11 2:38:56

题目:

请你仅使用两个队列实现一个后入先出(LIFO)的栈,并支持普通栈的全部四种操作(pushtoppop 和 empty)。

实现 MyStack 类:

  • void push(int x) 将元素 x 压入栈顶。
  • int pop() 移除并返回栈顶元素。
  • int top() 返回栈顶元素。
  • boolean empty() 如果栈是空的,返回 true ;否则,返回 false 。

注意:

  • 你只能使用队列的标准操作 —— 也就是 push to backpeek/pop from frontsize 和 is empty 这些操作。
  • 你所使用的语言也许不支持队列。 你可以使用 list (列表)或者 deque(双端队列)来模拟一个队列 , 只要是标准的队列操作即可。

栈的基本性质:后进先出

队列的基本性质:先进先出

解题思路:

创建两个队列qu1和qu2:

1.push(入栈)方法的实现:

若两个队列均为空,将待入栈的值(x) 通过队列提供的offer方法尾插到qu1中。

如果qu1不为空,将待入栈的值(x)通过offer方法尾插到qu1中

若qu2不为空,同理。

2.pop(出栈方法的实现)

出栈之前,通过empty方法判断qu1和qu2是否同时为空,为空,返回-1.

若qu1不为空,将qu1中前size-1个元素(通过队列的poll(出队列)方法获取qu1中的队头元素)尾插到qu2中,那么最后,qu1中队头元素即为要出栈的哪个元素,返回这个值即可。

若qu2不为空,同上。

3,top(得到栈顶元素):

将不为空的那个队列通过for循环全部尾插到另一个队列中,最后一个尾插的元素即为栈顶元素。

具体步骤的实现:

1.基本结构的实现:

声明并初始化两个底层为链表的队列:qu1 和 qu2.(在构造方法中初始化)

代码如下:

class useQueueStack {
    //声明两个队列
    public Queue<Integer> qu1;
    public Queue<Integer> qu2;

    public useQueueStack() {
        //初始化两个队列
        qu1 = new LinkedList<>();
        qu2 = new LinkedList<>();
    }

2.push(入栈)功能的实现:

判断pu1和pu2的状态:qu1不为空,将x尾插到qu1中,qu2不为空,将x尾插到qu2中(通过队列的offer方法实现),若两个队列都为空,则将x尾插到qu1中。

具体代码如下:

 //入栈功能的实现
    public void push(int x) {

        //若队列qu1不为空,将x尾插到qu1中
        if (!qu1.isEmpty()) {
             qu1.offer(x);
        } else if (!qu2.isEmpty()) {  //队列qu2不为空,将x尾插到qu2中
            qu2.offer(x);
        } else {  //若两者都为空,将元素尾插到qu1中
            qu1.offer(x);
        }
    }

3.出栈(pop)功能的实现:

判断当前两个队列是否为空,若都为空,返回-1.

若qu1不为空,创建一个变量size来接受qu1长度,通过for循环,将qu1中前size-1个元素尾插到qu2中,则剩下的qu1中的元素,就是要出栈的那一个元素。

qu2同上。

以下时qu1不为空的例子:

具体代码如下:

public int pop() { //出栈方法的实现
        if (empty()) { //判断两个队列是否都为空
            return -1;
        }
        //如果qu1不为空,将qu1中的前size-1个元素尾插到qu2中,qu1中最后的那个元素即为栈顶元素
        if (!qu1.isEmpty()) {
            int size = qu1.size(); //获取qu1的长度
            for (int i = 0; i < size - 1; i++) {
                qu2.offer(qu1.poll());
            }
            return qu1.poll(); //返回qu1遗留的最后一个元素
        } else {
         //qu2不为空
            int size = qu2.size();
            for (int i = 0; i < size - 1; i++) {
                qu1.offer(qu2.poll());
            }
            return qu2.poll();
        }
    }

4.获取栈顶元素功能(top)的实现:

在获取栈顶元素之前,判断队列是否为空,如果两个元素都为空,返回-1,

若qu1不为空,可以通过for循环,利用pop(队列的出队方法)将qu1的队头元素依次全部尾插到qu2中,最后插入的元素即为要获取的栈顶元素。,返回最后一个尾插元素。

若qu2不为空,同上。

以下时qu1不为空的例子:

具体代码如下:

//获取栈顶元素
    public int top() {
        if (empty()) {  //判断两个队列是否为空
          return -1;
        }
        if(!qu1.isEmpty()){
            int size = qu1.size();
            int val = qu1.poll();//每次插入前将qu1栈顶元素赋给val
            for (int i = 0; i < size; i++) {

                qu2.offer(qu1.poll());
            } //循环结束后最后一个插入的val即为栈顶元素
            return val;
        }else{
            int size = qu2.size();
            int val = qu2.poll()();
            for (int i = 0; i < size; i++) {
                qu1.offer(qu2.poll());
                }
            return val;

            }
        }

5.判断两个队列是否为空的方法empty:

布尔类型的方法

判断qu1和qu2是否同时为空。

具体代码如下:

//当qu1和qu2均为空时
    public boolean empty(){
       return qu1.isEmpty() &&  qu2.isEmpty();
    }
}

到这里,问题已经被解决了,喜欢的老铁来个三联吧!

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

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

相关文章

C++游戏开发详解:从入门到实践

目录 引言 使用C进行游戏开发的优势 常用的C游戏引擎和工具 C游戏引擎比较 开发工具 C游戏开发核心概念与代码示例 面向对象编程&#xff08;OOP&#xff09; 封装 继承 多态 内存管理 手动内存管理 智能指针 内存池 并发编程 多线程 同步机制 游戏开发流程 …

C#开发中如何在不破坏封装性下调用控件

在C#开发中&#xff0c;我们知道每个设计文件在完成后都会存在封装性&#xff0c;如果是方法&#xff0c;对象的调用&#xff0c;我们可以采取public方法来允许外部的访问&#xff0c;但是对于控件来说&#xff0c;封装性是与生俱来的&#xff0c;强行破环封装既复杂&#xff0…

【数据结构】图的最小生成树

快乐的流畅&#xff1a;个人主页 个人专栏&#xff1a;《C游记》《进击的C》《Linux迷航》 远方有一堆篝火&#xff0c;在为久候之人燃烧&#xff01; 文章目录 引言一、最小生成树的概念二、Kruskal算法2.1 思想2.2 实现 三、Prim算法3.1 思想3.2 实现 四、Kruskal和Prim的对比…

前缀和(7)_连续数组

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 前缀和(7)_连续数组 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. 题目链接…

使用python进行自然语言处理的示例

程序功能 分词&#xff1a;将输入句子拆分为单词。 词性标注&#xff1a;为每个单词标注其词性。 命名实体识别&#xff1a;识别命名实体&#xff08;如人名、地名、组织等&#xff09;。 这段代码展示了如何用 nltk 进行基础的 NLP 任务&#xff0c;包括分词、词性标注和命名…

17、CPU缓存架构详解高性能内存队列Disruptor实战

1.CPU缓存架构详解 1.1 CPU高速缓存概念 CPU缓存即高速缓冲存储器&#xff0c;是位于CPU与主内存间的一种容量较小但速度很高的存储器。CPU高速缓存可以分为一级缓存&#xff0c;二级缓存&#xff0c;部分高端CPU还具有三级缓存&#xff0c;每一级缓存中所储存的全部数据都是…

动态规划算法专题(一):斐波那契数列模型

目录 1、动态规划简介 2、算法实战应用【leetcode】 2.1 题一&#xff1a;第N个泰波那契数 2.1.1 算法原理 2.1.2 算法代码 2.1.3 空间优化原理——滚动数组 2.1.4 算法代码——空间优化版本 2.2 题二&#xff1a;三步问题 2.2.1 算法原理 2.2.2 算法代码 2.3 题二&a…

数据集-目标检测系列-鼠检测数据集 mouse >> DataBall

数据集-目标检测系列-鼠检测数据集 mouse >> DataBall 数据集-目标检测系列-老鼠检测数据集 mouse 数据量&#xff1a;6k 想要进一步了解&#xff0c;请联系。 DataBall 助力快速掌握数据集的信息和使用方式&#xff0c;会员享有 百种数据集&#xff0c;持续增加中。…

高效互动随心畅谈语聊大厅语音聊天系统小程序源码

高效互动随心畅谈 —— 语聊大厅语音聊天系统全解析 &#x1f389; 初识语聊大厅&#xff1a;语音社交的新大陆 在这个快节奏的数字时代&#xff0c;文字聊天似乎已经无法满足我们对即时互动和真实情感交流的需求。而“高效互动随心畅谈语聊大厅语音聊天系统”的出现&#xff…

TiDB 在线打标签实现副本调度应用实践

作者&#xff1a; 数据源的TiDB学习之路 原文来源&#xff1a; https://tidb.net/blog/4e14596a 案例背景 某原有系统为虚拟机环境部署&#xff0c;整体性能不满足预期。为提升集群整体性能&#xff0c;计划分阶段采购物理机&#xff0c;并以扩缩容的方式逐渐把物理机添加到…

如何从 Windows 11/10/8.1/8/7 中恢复已删除的视频

不小心删除了视频或格式化了 SD 卡/硬盘&#xff1f;没有备份已删除的视频&#xff1f;不要担心&#xff0c;我们有一个解决方案 可以恢复 Windows 11、10 中已删除的视频并处理这种可怕的情况。 但是&#xff0c;在详细介绍如何恢复已删除的视频和视频恢复应用程序之前&#…

【AI论文精读1】针对知识密集型NLP任务的检索增强生成(RAG原始论文)

目录 一、简介一句话简介作者、引用数、时间论文地址开源代码地址 二、摘要三、引言四、整体架构&#xff08;用一个例子来阐明&#xff09;场景例子&#xff1a;核心点&#xff1a; 五、方法 &#xff08;架构各部分详解&#xff09;5.1 模型1. RAG-Sequence Model2. RAG-Toke…

docker安装Portainer CE

docker安装Portainer CE 教程 1、简介 Portainer 是一款开源的容器管理工具&#xff0c;旨在帮助用户更轻松地管理 Docker 环境。无论您是 Docker 新手还是经验丰富的开发人员&#xff0c;Portainer 都提供了直观的用户界面&#xff0c;使您能够方便地创建、部署和监控容器。…

抖去推数字人---技术本地服务器技术开发步骤

AI数字人制作流程大致可以分为以下几个关键步骤&#xff1a; 虚拟形象设计&#xff1a;设计虚拟人物的外观和特征&#xff0c;可以手工完成&#xff0c;也可以利用计算机图形学和机器学习算法自动生成。 驱动/动作捕捉&#xff1a;使用动作捕捉技术记录真实演员的动作&#xf…

Rust Web自动化Demo

1.新建项目 使用RustCover新建项目&#xff0c;目录如下&#xff1a; Cargo.toml文件 [package] name "Demo" version "0.1.0" edition "2021"[dependencies] tokio { version "1", features ["full"] } thirtyfour…

【Android 源码分析】Activity短暂的一生 -- 目录篇 (持续更新)

1. 前言 忽然有一天&#xff0c;我想要做一件事&#xff1a;去代码中去验证那些曾经被“灌输”的理论。                                                                                  …

光电开关应用设计讨论

一. 检测原理 光电开关由一个发光管和一个光敏二极管或三极管组成。其原理很简单&#xff0c;发光二极管发出的光传递到光敏三极管&#xff0c;再转换成电信号。如图1所示&#xff0c;LED为发射端&#xff0c;正向电流IF越大&#xff0c;发射光的强度就越大&#xff1b;PT为接…

【小程序】微信小程序课程 -4 项目实战

目录 1、 效果图 2、创建项目 2.1 创建小程序端 2.1.1 先创建纯净项目 2.1.2 删除components 2.1.4 删除app.json红色部分 2.1.5 删除index.json红色部分 2.1.6 删除index.wxss全部内容 2.1.7 删除index.wxml全部内容 2.1.8 app.json创建4个页面 2.1.9 app.json添加…

【拥抱AIGC】通义灵码网络代理配置

在公司网络环境下&#xff0c;无法访问公共网络时&#xff0c;可在插件端配置网络代理后使用通义灵码。 配置网络代理 公司网络通常使用 HTTP 代理服务器在网络流量发送到目标位置之前进行拦截&#xff0c;以便检测可疑流量或者限制进入公司内网络的内容。如果你使用的公司网…

【Python报错已解决】 NameError: name ‘scio‘ is not defined

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 专栏介绍 在软件开发和日常使用中&#xff0c;BUG是不可避免的。本专栏致力于为广大开发者和技术爱好者提供一个关于BUG解决的经…