首页 > 文章列表 > 我们如何在Java中使用栈实现队列?

我们如何在Java中使用栈实现队列?

java 队列
463 2023-08-20

一个队列类扩展了集合接口,它支持使用先进先出(FIFO)的插入和删除操作。而向量类的子类,它表示了后进先出(LIFO)的对象堆栈。最后一个添加到栈顶的元素(入栈)可以是从栈中移除的第一个元素(出栈)。我们也可以在下面的程序中使用栈来实现一个队列。

示例

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