Java PriorityQueue retainAll() 方法



描述

java PriorityQueue retainAll(Collection<?> c) 方法保留在 ArrayDeque 物件和提供的集合元素中存在的公共元素,並刪除其他剩餘元素。此方法修改 ArrayDeque 物件。

宣告

以下是java.util.PriorityQueue.retainAll(Collection<?> c) 方法的宣告

public boolean retainAll​(Collection<?> c)

引數

c − 包含要從此集合中保留的元素的集合。

返回值

如果此 ArrayDeque 因呼叫而發生更改,則返回 true。

異常

NullPointerException − 如果此 ArrayDeque 包含一個或多個空元素,並且指定的集合不支援空元素,或者指定的集合為空。

保留 PriorityQueue 中整數的所有給定元素示例

以下示例顯示了使用整數的 Java PriorityQueue retainAll() 方法的使用方法。我們正在建立一個整數的 PriorityQueue,新增一些元素,列印它,然後使用 retainAll() 方法保留一些元素。由於 PriorityQueue 已被修改,因此會列印它以檢查是否保留了指定的元素。

package com.tutorialspoint;

import java.util.PriorityQueue;
import java.util.Arrays;

public class PriorityQueueDemo {
   public static void main(String[] args) {
      
      // create an empty priority queue
      PriorityQueue<Integer> queue = new PriorityQueue<>();

      // use add() method to add elements in the queue
      queue.add(25);
      queue.add(30);
      queue.add(20);
      queue.add(18);        

      // let us print all the elements available in queue
      System.out.println("PriorityQueue = " + queue);

      // it will retain two common elements
      System.out.println("PriorityQueue modified:  " + queue.retainAll(Arrays.asList(11,30,20,12)));
	  
      // let us print all the elements available in queue again
      System.out.println("PriorityQueue = " + queue);
   }
}

輸出

讓我們編譯並執行上述程式,這將產生以下結果:

PriorityQueue = [25, 30, 20, 18]
PriorityQueue modified:  true
PriorityQueue = [30, 20]

保留 PriorityQueue 中字串的所有給定元素示例

以下示例顯示了使用字串的 Java PriorityQueue retainAll() 方法的使用方法。我們正在建立一個字串的 PriorityQueue,新增一些元素,列印它,然後使用 retainAll() 方法保留一些元素。由於 PriorityQueue 已被修改,因此會列印它以檢查是否保留了指定的元素。

package com.tutorialspoint;

import java.util.PriorityQueue;
import java.util.Arrays;

public class PriorityQueueDemo {
   public static void main(String[] args) {
      
      // create an empty priority queue
      PriorityQueue<String> queue = new PriorityQueue<>();

      // use add() method to add elements in the queue
      queue.add("A");
      queue.add("B");
      queue.add("C");
      queue.add("D");        

      // let us print all the elements available in queue
      System.out.println("PriorityQueue = " + queue);

      // it will retain two common elements
      System.out.println("PriorityQueue modified:  " + queue.retainAll(Arrays.asList("E","B","C","F")));
	  
      // let us print all the elements available in queue again
      System.out.println("PriorityQueue = " + queue);
   }
}

輸出

讓我們編譯並執行上述程式,這將產生以下結果:

PriorityQueue = [A, B, C, D]
PriorityQueue modified:  true
PriorityQueue = [B, C]

保留 PriorityQueue 中物件的所有給定元素示例

以下示例顯示了使用 Student 物件的 Java PriorityQueue retainAll() 方法的使用方法。我們正在建立一個 Student 物件的 PriorityQueue,新增一些元素,列印它,然後使用 retainAll() 方法保留一些學生。由於 PriorityQueue 已被修改,因此會列印它以檢查是否保留了指定的元素。

package com.tutorialspoint;

import java.util.PriorityQueue;
import java.util.Arrays;

public class PriorityQueueDemo {
   public static void main(String[] args) {
      
      // create an empty priority queue
      PriorityQueue<Student> queue = new PriorityQueue<>();

      // use add() method to add elements in the queue
      queue.add(new Student(1, "Julie"));
      queue.add(new Student(2, "Robert"));
      queue.add(new Student(3, "Adam"));       

      // let us print all the elements available in queue
      System.out.println("PriorityQueue = " + queue);

      // it will return true after retaining two students from queue
      System.out.println("Student removed : " + queue.retainAll(
         Arrays.asList(new Student(2, "Robert"),new Student(3, "Adam"))));
	  
      // let us print all the elements available in queue again
      System.out.println("PriorityQueue = " + queue);
   }
}
class Student implements Comparable<Student> {
   int rollNo;
   String name;

   Student(int rollNo, String name){
      this.rollNo = rollNo;
      this.name = name;
   }

   @Override
   public String toString() {
      return "[ " + this.rollNo + ", " + this.name + " ]";
   }
   
   @Override
   public boolean equals(Object obj) {
      Student s = (Student)obj;
      return this.rollNo == s.rollNo && this.name.equalsIgnoreCase(s.name);
   }

   @Override
   public int compareTo(Student student) {
      return this.rollNo - student.rollNo;
   }
}

輸出

讓我們編譯並執行上述程式,這將產生以下結果:

PriorityQueue = [[ 1, Julie ], [ 2, Robert ], [ 3, Adam ]]
Student removed : true
PriorityQueue = [[ 2, Robert ], [ 3, Adam ]]
java_util_priorityqueue.htm
廣告
© . All rights reserved.