Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Java

เราจะนำ Queue ไปใช้งานโดยใช้ Stack ใน Java ได้อย่างไร


คิว คลาสขยาย คอลเลกชัน อินเทอร์เฟซและรองรับการแทรกและถอดการทำงานโดยใช้ เข้าก่อน-ออกก่อน (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