解析如何用两个栈来实现队列的方法

2016-02-19 09:20 6 1 收藏

下面请跟着图老师小编一起来了解下解析如何用两个栈来实现队列的方法,精心挑选的内容希望大家喜欢,不要忘记点个赞哦!

【 tulaoshi.com - 编程语言 】

题目:如何用两个栈来实现队列,即实现队列的两个方法——appendTail(插入)和deleteHead(删除)。
分析:核心思想是一个栈正向存储,另外一个栈逆向存储。正向存储的栈用来插入,逆向存储的栈用来删除。
实现的Java代码如下:
代码如下:

import java.util.Stack;
public class QueneWithTwoStacksE {
 private StackE stack1;
 private StackE stack2;
 public void appendTail(E e) {
  stack1.push(e);
 }
 public E deleteHead() throws Exception {
  if (stack2.size() = 0) {
   while (!stack1.isEmpty()) {
    stack2.push(stack1.pop());
   }
  }
  if (stack2.size() == 0) {
   throw new Exception("Queue is empty!");
  }
  return stack2.pop();
 }
}

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

来源:https://www.tulaoshi.com/n/20160219/1590404.html

延伸阅读
http://educationiseverywhere.pushstage.ca/ 这是一个日本东芝电脑相关的一个培训网站,整体风格充满着趣味,flash的动画做得非常精彩,尤其在froshed栏目里,翻出的书页象立体折纸的感觉几可乱真. 这是AU Design 和 YAMAHA 合作的乐器手机概念设计的原型网站, 3段折叠的那款,还有可以拉成四面体的手机,似乎是可以打碟的,超有意思。 http:/...
FunctionCompFile(F1asstring,F2asstring)asboolean Dimissameasboolean OpenF1ForBinaryAs#1 OpenF2ForBinaryAs#2 issame=True IfLOF(1)LOF(2)Then issame=False Else whole&=LOF(1)10000'numberofwhole10,000bytechunks part&=LOF(1)Mod10000'remainingbytesatendoffile buffer...
两个世界2 运行序列号 进入游戏后提示输入序列号,可用下面一组: JR2W-FY5U-R34N-YZU4 更多相关内容请关注:两个世界2专区 两个世界2 2小时游玩评价 玩了2个小时~谈谈自己的...
标签: Web开发
打包下载 自己写了一个很简单的jquery插件,在页面中调用其中的函数就可实现. 插件源代码(listtolist.js): 代码如下: /** fromid:源list的id. toid:目标list的id. moveOrAppend参数("move"或者是"append"): move -- 源list中选中的option会删除.源list中选中的option移动到目标list中,若目标list中已存在则该option不添加. append --...
《龙腾世纪 审判》两个灵魂位置详细解析 《龙腾世纪:审判》为一款RPG游戏,下面给大家介绍一下两个灵魂位置,以供玩家们参考。 位置1: 圣殿骑士,代表人物卡姐,增益核心技能:【集结】,可以让你的法师,盗贼披上一层战士那样的物理护盾,消耗专注值, 佩戴专注腰带。 【神佑之力】,消耗9耐力 24秒加全体队员伤害15%。 加点按...

经验教程

852

收藏

44
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部