原题例如以下:

Implement the following operations of a stack using queues.

  • push(x) -- Push element x onto stack.
  • pop() -- Removes the element on top of the stack.
  • top() -- Get the top element.
  • empty() -- Return whether the stack is empty.

Notes:

  • You must use only standard operations of a queue -- which means only push
    to back
    peek/pop from frontsize,
    and is empty operations are valid.
  • Depending on your language, queue may not be supported natively. You may simulate a queue by using a list or deque (double-ended queue), as long as you use only standard operations of a queue.
  • You may assume that all operations are valid (for example, no pop or top operations will be called on an empty stack).

基本思路是:如果有两个队列Q1和Q2,当二者都为空时。入栈操作能够用入队操作来模拟,能够随便选一个空队列,如果选Q1进行入栈操作。如今如果a,b,c依次入栈了(即依次进入队列Q1)。这时如果想模拟出栈操作,则须要将c出栈。由于在栈顶。这时候能够考虑用空队列Q2,将a,b依次从Q1中出队,而后进入队列Q2,将Q1的最后一个元素c出队就可以。此时Q1变为了空队列。Q2中有两个元素,队头元素为a。队尾元素为b。接下来如果再运行入栈操作,则须要将元素进入到Q1和Q2中的非空队列,即进入Q2队列,出栈的话,就跟前面的一样。将Q2除最后一个元素外所有出队,并依次进入队列Q1,再将Q2的最后一个元素出队就可以。

Java实现代码例如以下:

class MyStack {	LinkedList<Integer> queue1 = new LinkedList<Integer>();
LinkedList<Integer> queue2 = new LinkedList<Integer>();
// Push element x onto stack.
public void push(int x) {
if(queue1.size()==0&&queue2.size()==0)
{
queue1.offer(x);
}
else if(queue1.size()==0)
{
queue2.offer(x);
}
else
{
queue1.offer(x);
}
} // Removes the element on top of the stack.
public void pop() {
if(queue1.size()!= 0)
{
int length = queue1.size();
for(int i =0;i<length-1;i++)
{
queue2.offer(queue1.poll());
}
queue1.poll();
}
else
{
int length = queue2.size();
for(int i =0;i<length-1;i++)
{
queue1.offer(queue2.poll());
}
queue2.poll();
}
}
// Get the top element.
public int top() {
if(queue1.size()!= 0)
{
int length = queue1.size();
for(int i =0;i<length-1;i++)
{
queue2.offer(queue1.poll());
}
int result = queue1.element();
queue2.offer(queue1.poll());
return result;
}
else
{
int length = queue2.size();
for(int i =0;i<length-1;i++)
{
queue1.offer(queue2.poll());
}
int result = queue2.element();
queue1.offer(queue2.poll());
return result;
}
} // Return whether the stack is empty.
public boolean empty() {
return queue1.size()==0&&queue2.size()==0;
} }

最新文章

  1. EF上下文对象线程内唯一性与优化
  2. jquery/js实现一个网页同时调用多个倒计时(最新的)
  3. 全球最低功耗蓝牙单芯片DA14580的硬件架构和低功耗
  4. PAT 解题报告 1049. Counting Ones (30)
  5. UE 的使用
  6. PHP获得header头进行分析
  7. Rational Rose 7.0的使用(转)
  8. php代码效率小常识
  9. Java多线程之ReentrantLock与Condition
  10. python小程序--Three(三级菜单)
  11. Struts标签&lt;bean:write&gt;&lt;logic:iterate&gt;&lt;/logic:equal&gt;的组合使用小例
  12. github使用心得和链接
  13. BigDecimal - Java精确运算
  14. 6. Oracle闪回特性
  15. Jumpserver 介绍
  16. OpenStack之日志
  17. 详解Base64编码和解码
  18. 深入浅出Docker(六):像谷歌一样部署你的应用
  19. android中代码操作外部SD卡出错:W/System.err(1595): Caused by: libcore.io.ErrnoException: open failed: EACCES (Permission denied)
  20. C# WebBrowser获取指定字符串的坐标

热门文章

  1. ViewDragHelper详解
  2. Python的学习
  3. Form( 表单) 组件
  4. css优先级计算
  5. 腾讯云(centos)上安装apache
  6. The type or namespace name &#39;Script&#39; does not exist in the namespace &#39;System.Web&#39; (are you missing an assembly reference?)
  7. IActiveView 接口 - 浅谈
  8. POJ 1930 Dead Fraction
  9. pyqt5表格qtablewidget
  10. iOS 容易引“起循环引用”的三种场景