题目:

用两个栈实现一个队列。队列的声明如下,请实现它的两个函数appendTail和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能。

思路:

首先定义两个栈stack1、stack2,stack1用于插入,stack2用于删除。删除时如果直接出栈就无法实现先进先出,这时需要将stack1中的所有元素从stack1出栈,然后依次压入stack2中,然后再从stack2中出栈。如果stack2中有元素存在,那么直接出栈,无需将stack1中元素压入stack2中。只有当stack2中元素都为空时,才需要将stack1中元素取出。

代码:

 import java.util.Stack;

 /**
  *  两个栈实现队列
  * @author wydream
  *
  */

 public class TwoStackQueue {

     private Stack<Object> s1;//s1插入元素
     private Stack<Object> s2;//s2删除元素

     public TwoStackQueue() {
         s1=new Stack<Object>();
         s2=new Stack<Object>();
     }

     //插入元素
     public void push(Object obj) {
         s1.push(obj);
     }

     //元素出队列
     public Object pop() {
         if(s2.empty()&&s1.empty()) {
             return null;
         }
         if(s2.empty()) {
             System.out.println("s1中数据进入到s2");
             while(!s1.empty()) {
                 Object obj=s1.pop();
                 s2.push(obj);
             }
         }
         return s2.pop();
     }

     public static void main(String[] args) {
         TwoStackQueue tq=new TwoStackQueue();
         tq.push("北京");
         tq.push("上海");
         tq.push("深圳");
         tq.push("杭州");
         System.out.println(tq.pop());
         System.out.println(tq.pop());
         System.out.println(tq.pop());
         tq.push("武汉");
         System.out.println(tq.pop());
         System.out.println(tq.pop());
     }

 }

相关题目——两个队列实现栈:

 import java.util.LinkedList;
 import java.util.Queue;

 /**
  * 两个队列实现栈
  *
  * @author wydream
  *
  */

 public class TwoQueueStack {

     private Queue<String> queue1=new LinkedList<String>();
     private Queue<String> queue2=new LinkedList<String>();

     //向栈中压入元素
     public void push(String value) {
         //两个队列都为空时,优先考虑queue1
         if(queue1.isEmpty()&&queue2.isEmpty()) {
             queue1.add(value);
             return;
         }

         //如果queue1为空,queue2中有数据,则直接放入queue2中
         if(queue1.isEmpty()) {
             queue2.add(value);
             return;
         }

         //如果queue2为空,queue1有数据,直接放入queue1中
         if(queue2.isEmpty()) {
             queue1.add(value);
             return;
         }
     }

     //从栈中弹出一个数据
     public String pop() {
         //两个栈都为空
         if(queue1.isEmpty()&&queue2.isEmpty()) {
             System.out.println("栈为空");
             return null;
         }
         //如果queue1中没有元素,queue2中有元素,将其queue2中的元素依次放入queue1中,直到最后一个元素,弹出即可
         if(queue1.isEmpty()) {
             while(queue2.size()>1) {
                 queue1.add(queue2.poll());
             }
             return queue2.poll();
         }
         //如果queue2中没有元素,queue1中有元素,将其queue1中的元素依次放入queue2中,直到最后一个元素,弹出即可
         if(queue2.isEmpty()) {
             while(queue1.size()>1) {
                 queue2.add(queue1.poll());
             }
             return queue1.poll();
         }
         return null;
     }

     public static void main(String[] args) {
         TwoQueueStack ts=new TwoQueueStack();
         ts.push("北京");
         ts.push("上海");
         ts.push("广州");
         ts.push("深圳");

         System.out.println(ts.pop());
         System.out.println(ts.pop());
         ts.push("苏州");
         ts.push("杭州");
         System.out.println(ts.pop());
         System.out.println(ts.pop());

     }

 }

剑指offer(9)——用两个栈实现队列的更多相关文章

  1. 《剑指offer》用两个栈实现队列

    本题来自<剑指offer> 用两个栈实现队列 题目: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路: 队列定义:先进先出 栈定义:先进后出 要 ...

  2. 剑指 Offer 09. 用两个栈实现队列

    剑指 Offer 09. 用两个栈实现队列 用两个栈实现一个队列.队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的 ...

  3. [Leetcode]225. 用队列实现栈 、剑指 Offer 09. 用两个栈实现队列

    ##225. 用队列实现栈 如题 ###题解 在push时候搞点事情:push时入队1,在把队2的元素一个个入队1,再交换队2和队1,保持队1除pushguocheng 始终为空. ###代码 cla ...

  4. 剑指 Offer 09. 用两个栈实现队列 +java中栈和队列的使用

    剑指 Offer 09. 用两个栈实现队列 题目链接 class CQueue { private Stack<Integer> sta1; private Stack<Intege ...

  5. 力扣 - 剑指 Offer 09. 用两个栈实现队列

    目录 题目 思路 代码 复杂度分析 题目 剑指 Offer 09. 用两个栈实现队列 思路 刚开始想的是用stack1作为数据存储的地方,stack2用来作为辅助栈,如果添加元素直接push入stac ...

  6. 菜鸟刷题路:剑指 Offer 09. 用两个栈实现队列

    剑指 Offer 09. 用两个栈实现队列 用两个栈实现一个队列.队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的 ...

  7. 【Java】 剑指offer(8) 用两个栈实现队列

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集  题目 用两个栈实现一个队列.队列的声明如下,请实现它的两个函数append ...

  8. [剑指offer]09用两个栈实现队列插入和删除操作,C++实现

    原创博文,转载请注明出处! # 本文为牛客网<剑指offer>刷题笔记 1.题目 # 用两个栈实现队列的插入和删除操作 2.思路 栈服从先入后出的原则处理数据,队列服从先入先出的原则处理数 ...

  9. Go语言实现:【剑指offer】用两个栈实现队列

    该题目来源于牛客网<剑指offer>专题. 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. Go语言实现: var list1 = list.New( ...

  10. 剑指OFFER之用两个栈实现队列(九度OJ1512)

    题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 输入: 每个输入文件包含一个测试样例.对于每个测试样例,第一行输入一个n(1<=n<=100 ...

随机推荐

  1. [Android] i2c-toos 在 Android 上使用

    CPU:RK3399 系统:Android 7.1 i2c-tools 是一款免费开源的工具,可以检测 i2c 总线上的设备,可以读写寄存器等等 可以从下面路径下载需要的版本: https://www ...

  2. pytorch基础学习(二)

    在神经网络训练时,还涉及到一些tricks,如网络权重的初始化方法,优化器种类(权重更新),图片预处理等,继续填坑. 1. 神经网络初始化(Network Initialization ) 1.1 初 ...

  3. 知乎千万级高性能长连接网关 https://zhuanlan.zhihu.com/p/66807833

    知乎千万级高性能长连接网关揭秘 9 天前 · 来自专栏 知乎技术专栏 实时的响应总是让人兴奋的,就如你在微信里看到对方正在输入,如你在王者峡谷里一呼百应,如你们在直播弹幕里不约而同的 666,它们的背 ...

  4. Maven多镜像配置

    Maven阿里云镜像相信国内用得是很爽的,但有时候,一些版本的包明明可以在http://mvnrepository.com上搜索到.但你确实下载不来... 废话不多,settings.xml多镜像配置 ...

  5. Mac升级Node.js和npm到最新版本指令

    一.查看本机当前Node.js和npm版本 node -v npm -v 二.清除node.js的cache sudo npm cache clean -f 三.安装"n"版本管理 ...

  6. Android Studio创建Module-库模块

    Android Studio创建Module-库模块   本文链接:https://blog.csdn.net/niuba123456/article/details/81049676 模块是源文件和 ...

  7. 一个Flask应用运行过程剖析

    相信很多初学Flask的同学(包括我自己),在阅读官方文档或者Flask的学习资料时,对于它的认识是从以下的一段代码开始的: from flask import Flask app = Flask(_ ...

  8. 001-poi-excel-基础、单元格使用操作

    一.概述 Apache POI是Apache软件基金会的开源项目,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. .NET的开发人员则可以利用NPOI (POI ...

  9. 005-多线程-集合-Map-ConcurrentSkipListMap

    一.概述 ConcurrentSkipListMap是线程安全的有序的哈希表,适用于高并发的场景. ConcurrentSkipListMap和TreeMap,它们虽然都是有序的哈希表.但是,第一,它 ...

  10. osg create shape

    osg::ref_ptr<osg::Node> OSG_Qt_::createSimple() { osg::ref_ptr<osg::Geode> geode = new o ...