首頁  >  文章  >  Java  >  Java中如何使用Deque的pollFirst和pollLast函數進行雙端佇列彈出操作

Java中如何使用Deque的pollFirst和pollLast函數進行雙端佇列彈出操作

WBOY
WBOY原創
2023-06-26 17:49:482223瀏覽

Java中Deque(double ended queue,雙端佇列)是一種既可以在佇列頭部插入元素,也可以在佇列尾部插入元素的資料結構。它繼承自Queue接口,其實作類別有LinkedList和ArrayDeque。

Deque提供了許多彈出操作,包括pop,poll,pollFirst,pollLast,remove,removeFirst,removeLast等,這些操作都是從佇列中彈出元素並且從佇列中移除該元素。本文將著重於Deque中的pollFirst和pollLast函數的使用。

pollFirst方法彈出並且傳回雙端佇列的第一個元素,如果佇列為空,則傳回null。以下是pollFirst方法的宣告:

E pollFirst();

其中,E表示雙端佇列中的元素類型。

pollLast方法彈出並且傳回雙端佇列的最後一個元素,如果佇列為空,則傳回null。以下是pollLast方法的聲明:

E pollLast();

下面的範例展示瞭如何使用Deque的pollFirst和pollLast函數進行雙端佇列彈出操作:

import java.util.*;

public class DequeExample {
    public static void main(String[] args) {
        Deque<Integer> deque = new LinkedList<Integer>();
        
        deque.addFirst(1); //在队列头部插入元素
        deque.addFirst(2);
        deque.addLast(3); //在队列尾部插入元素
        deque.addLast(4);
        
        System.out.println(deque); // 输出 [2, 1, 3, 4]
        
        Integer firstElement = deque.pollFirst(); // 弹出队列头部的元素
        System.out.println("弹出的队列头部元素为: " + firstElement); // 输出 2
        System.out.println(deque); // 输出 [1, 3, 4]
        
        Integer lastElement = deque.pollLast(); // 弹出队列尾部的元素
        System.out.println("弹出的队列尾部元素为: " + lastElement); // 输出 4
        System.out.println(deque); // 输出 [1, 3]
    }
}

上述範例中,我們首先建立了一個雙端佇列LinkedList,然後使用addFirst和addLast函數向佇列中插入元素,接著使用pollFirst和pollLast函式彈出佇列頭部和尾部的元素。最後,我們列印出每個步驟後Deque中的元素。

總之,Deque類別是Java中非常有用的資料結構,它提供了許多功能,包括佇列的彈出操作。其中,pollFirst和pollLast函數可以幫助我們輕鬆地彈出佇列頭部和尾部的元素,並且Deque中的元素可以在任一段中插入和刪除。這些特性使Deque變得非常適用於一些場景,例如LRU Cache等。

以上是Java中如何使用Deque的pollFirst和pollLast函數進行雙端佇列彈出操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn