色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Java PriorityQueue數據結構接口原理及用法

瀏覽:3日期:2022-08-22 11:29:09

PriorityQueue是從JDK1.5開始提供的新的數據結構接口,它是一種基于優先級堆的極大優先級隊列。優先級隊列是不同于先進先出隊列的另一種隊列。每次從隊列中取出的是具有最高優先權的元素。如果不提供Comparator的話,優先隊列中元素默認按自然順序排列,也就是數字默認是小的在隊列頭,字符串則按字典序排列(參閱 Comparable),也可以根據 Comparator 來指定,這取決于使用哪種構造方法。優先級隊列不允許 null 元素。依靠自然排序的優先級隊列還不允許插入不可比較的對象(這樣做可能導致 ClassCastException)

優先級隊列是無界的,但是有一個內部容量,控制著用于存儲隊列元素的數組大小。它通常至少等于隊列的大小。隨著不斷向優先級隊列添加元素,其容量會自動增加。無需指定容量增加策略的細節

簡單應用:

package test;import java.util.PriorityQueue;public class PriorityQueueTest1 { @SuppressWarnings('unchecked') public static void main(String[] args) { PriorityQueue queue = new PriorityQueue(); queue.add('AAAAA'); // Add接受的參數是Obj,PriorityQueue使用integer String等基本的數據類型時,默認new時有參數,如果不寫則是按照默認排序 queue.add('BBBBB'); queue.add('CCCCC'); queue.add('DDDDD'); System.out.println(queue.peek()); // 獲取但不移除此隊列的頭 System.out.println(queue.poll()); // 獲取并移除此隊列的頭 System.out.println(queue.poll()); queue.offer('ZZZZZ'); // 將指定的元素插入此優先級隊列 System.out.println(queue.poll()); System.out.println(queue.poll()); System.out.println(queue.poll()); System.out.println(queue.poll()); // 到這里已經沒有元素,打印Null }}

定義比較器:

package test;import java.util.Comparator;import java.util.PriorityQueue;@SuppressWarnings('unchecked')public class PriorityQueueTest2 { private static PriorityQueue queue = new PriorityQueue(10,new Comparators()); public static void main(String[] args) { QueueObject queueObject = new QueueObject(); queueObject.setId(4); queueObject.setObject('AAAAA'); queue.add(queueObject); QueueObject queueObject1 = new QueueObject(); queueObject1.setId(1); queueObject1.setObject('BBBBB'); queue.add(queueObject1); QueueObject queueObject2 = new QueueObject(); queueObject2.setId(3); queueObject2.setObject('CCCCC'); queue.add(queueObject2); System.out.println(((QueueObject)queue.poll()).getObject()); System.out.println(((QueueObject)queue.poll()).getObject()); System.out.println(((QueueObject)queue.poll()).getObject()); }}class QueueObject { private int id; private Object object; public int getId() { return id; } public void setId(int id) { this.id = id; } public Object getObject() { return object; } public void setObject(Object object) { this.object = object; }}@SuppressWarnings('unchecked')class Comparators implements Comparator{ public int compare(Object arg0, Object arg1) { int val1 = ((QueueObject)arg0).getId(); int val2 = ((QueueObject)arg1).getId(); return val1 < val2 ? 0 : 1; }}

注意事項:

注意1:該隊列是用數組實現,但是數組大小可以動態增加,容量無限。

注意2:此實現不是同步的。不是線程安全的。如果多個線程中的任意線程從結構上修改了列表, 則這些線程不應同時訪問 PriorityQueue 實例,這時請使用線程安全的PriorityBlockingQueue 類。

注意3:不允許使用 null 元素。

注意4:此實現為插入方法(offer、poll、remove() 和 add 方法)提供 O(log(n)) 時間;

為 remove(Object) 和 contains(Object) 方法提供線性時間;為檢索方法(peek、element 和 size)提供固定時間。

注意5:方法iterator()中提供的迭代器并不保證以有序的方式遍歷優先級隊列中的元素。

至于原因可參考下面關于PriorityQueue的內部實現

如果需要按順序遍歷,請考慮使用 Arrays.sort(pq.toArray())。

注意6:可以在構造函數中指定如何排序。如:

PriorityQueue() 使用默認的初始容量(11)創建一個 PriorityQueue,并根據其自然順序來排序其元素(使用 Comparable)。 PriorityQueue(int initialCapacity) 使用指定的初始容量創建一個 PriorityQueue,并根據其自然順序來排序其元素(使用 Comparable)。 PriorityQueue(int initialCapacity, Comparator comparator) 使用指定的初始容量創建一個 PriorityQueue,并根據指定的比較器comparator來排序其元素。

注意7:此類及其迭代器實現了 Collection 和 Iterator 接口的所有可選 方法。

PriorityQueue的內部實現

PriorityQueue對元素采用的是堆排序,頭是按指定排序方式的最小元素。堆排序只能保證根是最大(最小),整個堆并不是有序的。

方法iterator()中提供的迭代器可能只是對整個數組的依次遍歷。也就只能保證數組的第一個元素是最小的

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 中文字幕一区二区三区免费视频 | 性盈盈影院影院67194 | 夜色1网站| 久久久久久久久久毛片精品美女 | 久揄揄鲁一二三四区高清在线 | 国产精品亚洲高清一区二区 | 成人免费aaaaa毛片 | 亚洲精品国产福利片 | 久久99久久99 | 亚洲成人免费在线观看 | 亚洲精品男人天堂 | 免费看欧美一级特黄a毛片 免费看片aⅴ免费大片 | 成年午夜性爽快免费视频不卡 | 午夜国产精品久久久久 | 一区二区亚洲精品 | 狼人总合狼人综合 | 国产婷婷一区二区三区 | 国产三级三级三级三级 | 亚洲国产日韩欧美综合久久 | 欧美yyy| a黄毛片| 男女乱淫真视频免费一级毛片 | 国产成人精品亚洲一区 | 午夜刺激爽爽视频免费观看 | 国产亚洲一区呦系列 | 美女被免费网站视频软件 | 免费看欧美一级特黄a毛片 免费看片aⅴ免费大片 | 欧美特级特黄a大片免费 | 国产在线一区二区三区四区 | 欧美videos另类齐全 | 午夜精品久久久久久99热7777 | 精品久久久久久免费影院 | 欧美精品成人一区二区在线观看 | 亚洲爆爽 | 免费人成黄页在线观看视频国产 | 欧美一级毛片无遮无挡 | 色视频在线观看免费 | 黄色一级片网址 | 欧美另类精品一区二区三区 | 国产一区二区三区在线观看视频 | 欧美一级α片毛片免费观看 |