如何使用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
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语