如何用 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
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP