用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 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();
}
}