คิว คลาสขยาย คอลเลกชัน อินเทอร์เฟซและรองรับการแทรกและถอดการทำงานโดยใช้ เข้าก่อน-ออกก่อน (FIFO) . กอง เป็นคลาสย่อยของ เวกเตอร์ คลาสและเป็นตัวแทนของ เข้าก่อนออกก่อน (LIFO) กองวัตถุ องค์ประกอบสุดท้ายที่เพิ่มที่ด้านบนของสแต็ก (ใน) สามารถเป็นองค์ประกอบแรกที่จะลบ (ออก) ออกจากสแต็ก นอกจากนี้เรายังสามารถใช้ Queue โดยใช้ Stack ในโปรแกรมด้านล่างได้
ตัวอย่าง
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