为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用两个堆栈实现队列?

如何使用两个堆栈实现队列?

假设我们有两个堆栈,没有其他临时变量。是否可以仅使用两个堆栈来“构造”队列数据结构?
查看完整描述

3 回答

?
扬帆大鱼

TA贡献1799条经验 获得超9个赞

保留2叠,我们称它们为inbox和outbox。


入队:


将新元素推到 inbox

出队:


如果outbox为空,则通过从中弹出每个元素inbox并将其推入来重新填充它outbox


弹出并从返回顶部元素 outbox


使用此方法,每个元素将在每个堆栈中恰好出现一次-意味着每个元素将被推入两次并弹出两次,从而提供了摊销的固定时间操作。


这是Java的实现:


public class Queue<E>

{


    private Stack<E> inbox = new Stack<E>();

    private Stack<E> outbox = new Stack<E>();


    public void queue(E item) {

        inbox.push(item);

    }


    public E dequeue() {

        if (outbox.isEmpty()) {

            while (!inbox.isEmpty()) {

               outbox.push(inbox.pop());

            }

        }

        return outbox.pop();

    }


}


查看完整回答
反对 回复 2019-11-04
  • 3 回答
  • 0 关注
  • 1241 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信