日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:24日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲免费高清| 亚洲一区资源| 日本午夜精品久久久久| 久久国产麻豆精品| 国产精品美女久久久久久不卡| 美女视频黄 久久| 韩国精品主播一区二区在线观看| 欧美日韩四区| 日韩激情视频网站| 成人台湾亚洲精品一区二区 | 欧美一区影院| 精品久久影院| 欧美福利一区| 69堂精品视频在线播放| 一区二区三区四区日本视频| 国产一区导航| 国产精品自在| 高清不卡亚洲| 一区二区三区国产盗摄| 久久久久九九精品影院| 在线 亚洲欧美在线综合一区| 日本欧美韩国一区三区| 国产色播av在线| 中文字幕成人| 日本在线啊啊| 奇米亚洲欧美| 激情欧美丁香| 国产高清精品二区| 黑丝一区二区| 牛牛精品成人免费视频| 在线综合欧美| 激情中国色综合| 免费一级片91| 国产成人a视频高清在线观看| 国产毛片久久| 91日韩在线| 日韩综合一区二区| 久久婷婷一区| 久久亚洲人体| 亚洲精品高潮| 香蕉精品久久| 里番精品3d一二三区| 国产毛片久久| 91看片一区| 欧美精品国产白浆久久久久| 国产一区日韩欧美| 麻豆国产精品| 亚洲三级国产| 五月天激情综合网| 中文在线а√天堂 | 国产精品主播在线观看| 好吊日精品视频| 亚洲国产成人二区| 国产毛片一区二区三区| 视频一区中文字幕| 91精品综合| 国产成人免费| 欧美亚洲一级| 蜜桃一区二区三区在线观看| 久久婷婷亚洲| 吉吉日韩欧美| 九九九精品视频| 日本91福利区| 中文视频一区| 99视频精品| 亚洲一本视频| 99精品视频精品精品视频| 黄色网一区二区| 欧美激情麻豆| 国产精品密蕾丝视频下载| 婷婷久久免费视频| 首页欧美精品中文字幕| 视频一区中文| 日韩精品欧美激情一区二区| 动漫av一区| 美女尤物国产一区| 日韩福利视频网| 亚洲一区免费| 国产精品丝袜xxxxxxx| 91九色精品| 激情综合在线| 欧美理论视频| 免费国产自久久久久三四区久久| 久久免费国产| 欧美sss在线视频| 日韩免费看片| 桃色一区二区| 少妇精品导航| 欧洲av一区二区| 青青久久av| 久久婷婷av| 亚洲午夜一级| 女人天堂亚洲aⅴ在线观看| 蜜臀91精品国产高清在线观看| 亚洲高清av| 国产视频久久| 亚洲丝袜美腿一区| 香蕉久久久久久| 日韩av在线播放中文字幕| 97se亚洲| 国产精品视频3p| 精品视频一二| 日韩精品诱惑一区?区三区| 欧美aa在线观看| 久久久精品日韩| 亚洲午夜精品久久久久久app| 欧美一区二区三区高清视频| 国产综合欧美| 国产精品嫩草99av在线| 中文字幕一区二区三区在线视频| 日韩影院免费视频| 日韩三级一区| 国产精品一在线观看| 国产精品草草| 成人亚洲一区二区| 日韩精品免费一区二区在线观看| 在线日韩电影| 视频精品一区二区| 青青草精品视频| 精品99在线| 久久精品99久久无色码中文字幕| 99精品综合| 六月天综合网| 欧美日本久久| 狠狠躁少妇一区二区三区| 久久久久久久久丰满| 亚洲在线成人| 91精品国产自产精品男人的天堂| 欧美激情视频一区二区三区免费| 亚洲永久av| 国产精品色网| 国产精品美女久久久久久不卡| 高清av不卡| 亚洲专区一区| 国产精品一站二站| 欧美日韩尤物久久| 亚洲狼人精品一区二区三区| 青青草91视频| 三上悠亚国产精品一区二区三区 | 国产精品一区二区精品视频观看 | 日韩中文一区二区| 精品视频一区二区三区四区五区| 欧美日韩在线播放视频| 午夜久久av | 欧美性www| www.51av欧美视频| 国产精品婷婷| 国产精品第一| 狠狠色狠狠色综合日日tαg| 日本一区二区三区视频在线看| 麻豆91在线播放| 亚洲综合国产| 美女久久精品| 久久国产精品亚洲77777| 久久精品伊人| 香蕉成人久久| 久久永久免费| 丝袜美腿亚洲一区| 牛牛精品成人免费视频| 亚洲福利免费| 欧美精品影院| 亚洲午夜久久久久久尤物| 欧美精品国产一区| 欧美成人久久| 欧美久久亚洲| 制服诱惑一区二区| 精品福利久久久| 五月激激激综合网色播| 日韩在线看片| 欧美日韩亚洲一区二区三区在线| 久久亚洲精品中文字幕蜜潮电影| 日本欧美大码aⅴ在线播放| 久久久精品久久久久久96| 91精品日本| 伊人精品视频| 福利在线一区| 日韩精品一页| 蜜桃成人av| 国产成人a视频高清在线观看| 亚洲伊人影院| 亚洲午夜电影| 国产成年精品| 日韩精品一区二区三区av| 久久久久久久久99精品大| 国产精品theporn| 综合色就爱涩涩涩综合婷婷| 久久久久久久久丰满| 麻豆国产91在线播放| 巨乳诱惑日韩免费av| а√天堂8资源在线| 国产色噜噜噜91在线精品| 亚洲免费播放| 日韩久久精品网| 欧美国产视频| 亚洲久久视频| 99riav1国产精品视频| 欧美gv在线| 韩国女主播一区二区三区| 国产欧美一区二区色老头| 日韩中文字幕1|