解析如何用两个栈来实现队列的方法
摘要:题目:如何用两个栈来实现队列,即实现队列的两个方法——appendTail(插入)和deleteHead(删除)。分析:核心思想是一个栈正向...
题目:如何用两个栈来实现队列,即实现队列的两个方法——appendTail(插入)和deleteHead(删除)。
分析:核心思想是一个栈正向存储,另外一个栈逆向存储。正向存储的栈用来插入,逆向存储的栈用来删除。
实现的Java代码如下:
复制代码 代码如下:
import java.util.Stack;
public class QueneWithTwoStacks<E> {
private Stack<E> stack1;
private Stack<E> stack2;
public void appendTail(E e) {
stack1.push(e);
}
public E deleteHead() throws Exception {
if (stack2.size() <= 0) {
while (!stack1.isEmpty()) {
stack2.push(stack1.pop());
}
}
if (stack2.size() == 0) {
throw new Exception("Queue is empty!");
}
return stack2.pop();
}
}
【解析如何用两个栈来实现队列的方法】相关文章:
★ java使double保留两位小数的多方法 java保留两位小数
★ 基于JAVA中使用Axis发布/调用Webservice的方法详解
★ java基本教程之常用的实现多线程的两种方式 java多线程教程
★ java使用JNA(Java Native Access)调用dll的方法
下一篇:
用递归查找有序二维数组的方法详解