java使用队列实现栈思路_算法面试:队列实现栈的方案

声明:码字不易,转载请注明出处,欢迎文章下方讨论交流。

前言:Java数据结构与算法专题会不定时更新,欢迎各位读者监督。本篇介绍的是如何用两个队列实现栈的问题。这道题作为上一篇文章算法面试:栈实现队列的方案的姊妹篇(也是一道思路拓展题),本文给出问题的解决思路和Java实现代码。

首先定义两个队列分别为queue1和queue2。

1.大体思路:

队列实现栈,栈的特点是后进的先出,我们可以让元素入队queue1,留下队尾元素让其他元素出队,暂存到queue2中,然后让queue1中剩下的元素出队,即最后进的最先出来。

2.基本解决方案

按照上述的大体思路,我们给出解决方案:入栈和出栈都在queue1中完成,queue2只作为临时中转空间。

入栈 入队queue1

出栈 除queue1队尾的元素外将其他所有元素出队queue1,再入队queue2(中转暂存),然后将queue1中的元素出队(出栈)。最后一步,将暂存在queue2中的元素再倒回queue1中。

为描述清晰,请看下图:295c18eefe93565711ad1aef460de2c6.png

事实上,这个思路和用两个栈实现队列的方案1类似,都是第二个数据区作为暂存中转,最后在倒回到第一个数据区。

3.改进后的方案

上述方案是一个基本的最容易想到的解决方案,但是仔细观察会发现其并不完美:在每次出栈步骤中要把queue2中的元素倒回到queue1中,这个操作很累赘,能否优化一下,可不可以不用每次先出栈后倒回??下面给出改进后的方案

入栈:

两个队列全空:任选一个队列让元素入队,此处规定queue1

两个队列一个空:让元素入队非空的队列

注:不考虑两个队列全满,因为本身没意义

出栈: 将非空队列中除最后入队的元素之外的其他所有元素入队到另外一个队列中,然后出队剩下的那个元素(后进来的先出去,完成出栈)

相比于基本方案,改进后的方案没有了基本方案中的倒回操作,整个流程变得简洁高效,下面给出改进方案的java代码实现。

4.java代码实现

public class Queues2Stack {

private ArrayQueue q1;

private ArrayQueue q2;

private int maxLength;

public Queues2Stack(int capacity){

maxLength = capacity;

q1 = new ArrayQueue(capacity);

q2 = new ArrayQueue(capacity);

}

public int getSize(){

return q1.getsize()+q2.getsize();

}

/**

* 入栈:

* @param element 入栈元素

* @return 入栈成功结果?

*/

public boolean push(int element){

if(getSize() == maxLength){ //队列都满,此情景无意义

return false;

}

if(q2.isEmpty()){

q1.put(element);

}else{

q2.put(element);

}

return true;

}

/**

* 出栈

* @return 出栈元素

*/

public Object pop(){

if(getSize()==0){

throw new IndexOutOfBoundsException("空栈,无元素可出栈");

}else{ //留非空队列中最后一个元素,其他搬到空队列中

if(q2.isEmpty()){

while(q1.getsize()>1) q2.put(q1.pull());

return q1.pull(); //出队最后一个,实现后进先出

}else{

while(q2.getsize()>1) q1.put(q2.pull());

return q2.pull(); //出队最后一个,实现后进先出

}

}

}

}

测试程序:

public class Queues2StackTest {

public static void main(String[] args) {

Queues2Stack s = new Queues2Stack(5);

s.push(1);

s.push(2);

s.push(3);

System.out.println(s.pop()); //返回3

s.push(4);

s.push(5);

System.out.println(s.pop()); //返回5

System.out.println(s.pop()); //返回4

System.out.println(s.pop()); //返回2

System.out.println(s.pop()); //返回1

System.out.println(s.pop()); //抛出异常:提示栈为空

}

}

本篇的姊妹篇请移步到之前的文章算法面试:栈实现队列的方案

欢迎讨论提问,觉得文章对您有用,请收藏点个赞 ^_^

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

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

相关文章

Uber如何使用go语言创建高效的查询服务

在2015年初我们创建了一个微服务,它只做一件事(也确实做得很好)就是地理围栏查询。一年后它成了Uber高频查询(QPS)服务,本次要讲的故事就是我们为什么创建这个服务,以及编程语言新秀Go如何帮我们…

centos7:塔建pure_ftpd虚拟用户

2019独角兽企业重金招聘Python工程师标准>>> 1.下载pure_ftpd,上传服务器,目录路径:/usr/local/src/ 下载地址:https://pan.baidu.com/s/1kWe8FAn 2.安装pure_ftpd cd /usr/local/srctar -xjf pure-ftpd-1.0.36.tar.bz2cd pure-ftpd-1.0.36./configure -…

寒武纪芯片——有自己的SDK,支持tf、caffe、MXNet

寒武纪芯片产品中心>智能处理器IP智能处理器IP MLU智能芯片 软件开发环境 Cambricon-1A 高性能硬件架构及软件支持兼容Caffe、Tensorflow、MXnet等主流AI开发平台,已多次成功流片 国际上首个成功商用的深度学习处理器IP产品,可广泛应用于计算机视觉、…

基于百度语音识别API的Python语音识别小程序

一、功能概述 实现语音为文字,可以扩展到多种场景进行工作,这里只实现其基本的语言接收及转换功能。 在语言录入时,根据语言内容的多少与停顿时间,自动截取音频进行转换。 工作示例: 二、软件环境 操作系统&#xff1a…

spring框架结构介绍

Spring提供了一站式解决方案: 1) Spring Core spring的核心功能: IOC容器, 解决对象创建及依赖关系 2) Spring Web Spring对web模块的支持。 -->可以与struts整合,让struts的action创建交给spring -->spring mvc模式 3…

百度坐标转换API使用

http://api.map.baidu.com/geoconv/v1/?coords121.54759,29.870724&from1&to5&aksGSOaO07WkRHHiCRxxbSQVBn 前提:121.54759,29.870724 是由手机硬件或谷歌地图获取的 错误的方法一: function standard2china(lng,lat){//http://api.map.ba…

如何解决ajax跨域问题

原文:http://www.congmo.net/blog/2012/06/27/ajax-cross-domain/ 跨域问题 起 因是这样的,为了复用,减少重复开发,单独开发了一个用户权限管理系统,共其他系统获取认证与授权信息,暂且称之为A系统&#xf…

MySQL数据库是非关系_MySQL(数据库)基础知识、关系型数据库yu非关系型数据库、连接认证...

什么是数据库?数据库(Database):存储数据的仓库高效地存储和处理数据的介质(介质主要是两种:磁盘和内存)数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼DBS DBMS DBDBMS&…

Spring properties定义bean

2019独角兽企业重金招聘Python工程师标准>>> Spring提供了丰富的标签和注解来进行bean的定义,除此之外框架来提供了扩展机制让使用可以通过properties来定义bean,与强大的标签式和注解式的bean定义相比,properties提供的规则要简单…

mongodb java 单例_Java单例MongoDB工具类

我经常对MongoDB进行一些基础操作,将这些常用操作合并到一个工具类中,方便自己开发使用。没用Spring Data、Morphia等框架是为了减少学习、维护成本,另外自己直接JDBC方式的话可以更灵活,为自己以后的积累留一个脚印。Java驱动版本…

Oracle中执行存储过程call和exec区别

在sqlplus中这两种方法都可以使用: exec pro_name(参数1..); call pro_name(参数1..); 区别: 1. 但是exec是sqlplus命令,只能在sqlplus中使用;call为SQL命令,没有限制. 2. 存储过程没有参数时,exec可以直接跟过…

每秒处理10万订单乐视集团支付架构

原文:http://www.iteye.com/news/31550 ----------- 随着乐视硬件抢购的不断升级,乐视集团支付面临的请求压力百倍乃至千倍的暴增。作为商品购买的最后一环,保证用户快速稳定的完成支付尤为重要。所以在15年11月,我们对整个支付…

X--名称空间详解

转自:http://blog.csdn.net/lisenyang/article/details/18312039 X名称空间里面的成员(如X:Name,X:Class)都是写给XAML编译器看的、用来引导XAML代码将XAML代码编译为CLR代码。 4.1X名称空间里面到底都有些什么? x名称空间映射的是:http://schemas.microsoft.com/wi…

事物 php,什么是php事务

事务:用于保证数据的一致性,他由一组相关的dml语句组成,改组的dml语句要么全部成功,要么全部失败。当前版本的插件并不是事务安全的,因为他并没有识别全部的事务操作。SQL 事务单元是在单一服务器中运行的。插件并不能…

Flask form(登录,注册)

用户登录 from flask import Flask, render_template, request, redirect from wtforms import Form from wtforms.fields import core from wtforms.fields import html5 from wtforms.fields import simple from wtforms import validators from wtforms import widgetsapp …

怎么看so文件是哪个aar引进来的_手机爱奇艺下载视频存在哪个文件夹

我们很多朋友喜欢看视频使用爱奇艺观看,并且喜欢直接把视频缓冲到手机里,或是直接下载视频文件,但是经常不知道手机爱奇艺下载视频存在哪个文件夹,不知道怎么分享给好友或是传到电脑上,下面就来简单介绍一下。手机爱奇…

esxi能直通的显卡型号_显卡刷bios教程

一般来说显卡默认的出厂bios就已经很稳定,如果没有特殊情况下建议不要刷显卡bios。一般而言部分网友刷显卡BIOS目的是开核或超频,那么对于一个不会刷显卡bios的网友来说肯定会问显卡怎么刷bios类似的问题,那么本文这里就说一下有关显卡怎么刷…

关于Linux网卡调优之:RPS (Receive Packet Steering)

昨天在查LVS调度均衡性问题时,最终确定是 persistence_timeout 参数会使用IP哈希。目的是为了保证长连接,即一定时间内访问到的是同一台机器。而我们内部系统,由于出口IP相对单一,所以总会被哈希到相同的RealServer。 过去使用LVS…

footer.php置底,CSS五种方式实现Footer置底

页脚置底(Sticky footer)就是让网页的footer部分始终在浏览器窗口的底部。当网页内容足够长以至超出浏览器可视高度时,页脚会随着内容被推到网页底部;但如果网页内容不够长,置底的页脚就会保持在浏览器窗口底部。方法一:将内容部分…

安卓adapter适配器作用_自带安卓系统的便携屏,能玩出什么花样?

之前说到去年出差太多,平常就把便携屏带上了。之前也说了如果是像笔者这样的出差狗也知道,托运需要提前去机场一路着急忙慌,不托运只需要打印登机牌(纸质才给报销)排队安检登机就完了。有的时候可以把标准显示器来回寄,只要包装强…