如何用 Java 在棧中實現佇列?


佇列類擴充套件了集合介面,並使用先進先出 (FIFO) 支援插入和刪除操作。棧是向量類的子類,它表示後進先出 (LIFO) 物件棧。

新增到棧頂的最後一個元素 (In) 可以是從棧中移除的第一個元素 (Out)。我們還可以在下面的程式中使用棧實現佇列。

舉例

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

更新日期: 2023 年 11 月 23 日

2K+ 次瀏覽

開啟職業生涯 征程

完成課程後獲得認證

開始
廣告