码迷,mamicode.com
首页 > 其他好文 > 详细

用两个stack设计一个队列

时间:2014-08-20 01:22:06      阅读:204      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   java   数据   ar   div   log   

 

思路:用两个栈,一个用于接收(in),一个用于输出(out),输出前如果out为空需要将in中的数据导入out。

 

import java.util.Stack;

//用两个stack设计一个队列 p142

public class MyQueue<T> {
    Stack<T> in;
    Stack<T> out;

    public MyQueue() {
        in = new Stack<T>();
        out = new Stack<T>();
    }

    public void enqueue(T a) {
        in.push(a);
    }

    public T dequeue() {
        shiftItems();
        return out.pop();
    }

    public T peek() {
        shiftItems();
        return out.peek();
    }

    private void shiftItems() {
        if (!out.isEmpty())
            return;
        while (!in.isEmpty()) {
            out.push(in.pop());
        }
    }

    public static void main(String[] args) {
        MyQueue<Integer> queue = new MyQueue<Integer>();
        queue.enqueue(1);
        queue.enqueue(2);
        queue.enqueue(3);

        System.out.println(queue.dequeue());

        queue.enqueue(4);
        System.out.println(queue.dequeue());
        System.out.println(queue.dequeue());
        System.out.println(queue.dequeue());

    }

}

 

用两个stack设计一个队列,布布扣,bubuko.com

用两个stack设计一个队列

标签:style   blog   color   java   数据   ar   div   log   

原文地址:http://www.cnblogs.com/jdflyfly/p/3923597.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!