如何使用Java中的Stack实现队列?
Queue类扩展了Collection 接口,它支持使用先进先出(FIFO)插入和删除操作。Stack是Vector 类的一个子类,它表示对象的后进先出(LIFO)堆栈。添加到堆栈顶部的最后一个元素(In)可以是从堆栈中删除的第一个元素(Out)。我们也可以在下面的程序中使用 Stack实现一个Queue。
示例
import java.util.*; public class QueueUsingStackTest { private Stack stack1 = new Stack<>(); private Stack stack2 = new Stack<>(); public void enqueue(int element) { stack1.push(element); System.out.println(element + " inserted"); } public void dequeue() { if(stack2.isEmpty()) { while (!stack1.isEmpty()) { stack2.push(stack1.pop()); } } System.out.println(stack2.pop() + " removed"); } public static void main(String args[]) { QueueUsingStackTest test = new QueueUsingStackTest(); test.enqueue(10); test.enqueue(50); test.enqueue(100); test.dequeue(); } }
输出结果
10 inserted 50 inserted 100 inserted 10 removed