如何创建Java优先级队列来忽略重复项?

创建一个用于忽略重复的java优先级队列的最简单方法是首先创建一个集实现-

HashSet <Integer> set = new HashSet <> ();
set.add(100);
set.add(150);
set.add(250);
set.add(300);
set.add(250);
set.add(500);
set.add(600);
set.add(500);
set.add(900);

现在,创建优先级队列,并在上面的集合中包含删除重复项的集合-

PriorityQueue<Integer>queue = new PriorityQueue<>(set);

示例

import java.util.HashSet;
import java.util.PriorityQueue;
public class Demo {
   public static void main(String[] args) {
      HashSet<Integer>set = new HashSet<>();
      set.add(100);
      set.add(150);
      set.add(250);
      set.add(300);
      set.add(250);
      set.add(500);
      set.add(600);
      set.add(500);
      set.add(900);
      PriorityQueue<Integer>queue = new PriorityQueue<>(set);
      System.out.println("没有重复的元素 = "+queue);
   }
}

输出结果

没有重复的元素 = [100, 150, 250, 500, 600, 900, 300]