用两个栈实现队列java

用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )

解题思路:
双栈可实现列表倒序: 设有含三个元素的栈 A = [1,2,3]和空栈 B = []。若循环执行 A 元素出栈并添加入栈 B,直到栈 A 为空,则 A=[] , B = [3,2,1],即 栈 B元素实现栈A元素倒序 。
利用栈 B 删除队首元素: 倒序后,B执行出栈则相当于删除了A的栈底元素,即对应队首元素。

class CQueue {

    LinkedList<Integer> A,B;
    public CQueue() {
        A=new LinkedList<Integer>();
        B=new LinkedList<Integer>();
    }
    
    public void appendTail(int value) {
        A.addLast(value);
    }
    
    public int deleteHead() {
        if(!B.isEmpty()) return B.removeLast();
        if(A.isEmpty()) return -1;
        while(!A.isEmpty())
            B.addLast(A.removeLast());
            return B.removeLast();
    }
}
发布了23 篇原创文章 · 获赞 1 · 访问量 464

猜你喜欢

转载自blog.csdn.net/qq_40492920/article/details/105189456