欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java優(yōu)先隊列PriorityQueue中Comparator的用法詳解

 更新時間:2020年02月24日 11:48:42   作者:Tuzi294  
這篇文章主要介紹了java優(yōu)先隊列PriorityQueue中Comparator的用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在使用java的優(yōu)先隊列PriorityQueue的時候,會看到這樣的用法。

PriorityQueue<Integer> queue = new PriorityQueue<Integer>(new Comparator<Integer>(){
 @Override
 public int compare(Integer o1, Integer o2){
 return o1.compareTo(o2);
 }
});

那這樣到底構(gòu)造的是最大優(yōu)先還是最小優(yōu)先隊列呢?

看看源碼

看看offer(我也想要offer:X):

public boolean offer(E e) {
    if (e == null) {
      throw new NullPointerException();
    } else {
      ++this.modCount;
      int i = this.size;
      if (i >= this.queue.length) {
        this.grow(i + 1);
      }

      this.siftUp(i, e);
      this.size = i + 1;
      return true;
    }
  }

1)if和else,分別執(zhí)行對象判空和容量判斷
2)執(zhí)行siftUp(i, e),i是原有隊列長度,e是要入隊的元素。

siftUp是堆中調(diào)整元素位置的一種方法,可以看出這里的優(yōu)先隊列是使用最大/最小堆實現(xiàn)的。接著看siftUp:

private void siftUp(int k, E x) {
    if (this.comparator != null) {
      siftUpUsingComparator(k, x, this.queue, this.comparator);
    } else {
      siftUpComparable(k, x, this.queue);
    }

  }

看看使用了comparator的方法,k是原有隊列長度,x是入隊元素,queue是隊列,comparator是比較器:

private static <T> void siftUpUsingComparator(int k, T x, Object[] es, Comparator<? super T> cmp) {
    while(true) {
      if (k > 0) {
        int parent = k - 1 >>> 1;
        Object e = es[parent];
        if (cmp.compare(x, e) < 0) {
          es[k] = e;
          k = parent;
          continue;
        }
      }

      es[k] = x;
      return;
    }
  }

1)k>0,隊列長度大于0
2)parent = k - 1 >>> 1; 即(k-1)/2,表示最后一個非葉子節(jié)點的位置
3)e為父節(jié)點,x是入隊元素,x可以看做放在最后一個位置。如果compare(x, e) < 0,則執(zhí)行元素往上走的方法。
注:在siftUp中,如果是最小堆,那么應(yīng)該是較小的元素往上走,如果是最大堆,則應(yīng)該是較大的元素往上走。

由于源碼中新入隊元素x是在第1個參數(shù)的位置,因此最大/最小優(yōu)先隊列主要根據(jù)第1個參數(shù)的大小關(guān)系來判斷。

//對于最大堆,當(dāng)x>e時,讓x上升,則 x>e時返回負(fù)數(shù),即
int compare(Integer x, Integer e){
 return x > e ? -1 : 1;
}
//對于最小堆,當(dāng)x<e時,讓compare(x, e) < 0,即
int compare(Integer x, Integer e){
 return x < e ? -1 : 1; // return x.compareTo(e);
}

結(jié)論:

// 最小優(yōu)先隊列,直接 return o1.compareTo(o2);
PriorityQueue<Integer> queue = new PriorityQueue<Integer>(new Comparator<Integer>(){
 @Override
 public int compare(Integer o1, Integer o2){
 return o1 < o2 ? -1 : 1;
 /* e.g., return o1.compare(o2); */
 }
});
// 最大優(yōu)先隊列,則反過來 return o2.compareTo(o1);

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • spring注解之@Valid和@Validated的區(qū)分總結(jié)

    spring注解之@Valid和@Validated的區(qū)分總結(jié)

    @Validated和@Valid在基本驗證功能上沒有太多區(qū)別,但在分組、注解地方、嵌套驗證等功能上有所不同,下面這篇文章主要給大家介紹了關(guān)于spring注解之@Valid和@Validated區(qū)分的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • Spring Cache實現(xiàn)緩存技術(shù)

    Spring Cache實現(xiàn)緩存技術(shù)

    在面對公司緩存技術(shù)混亂時,張三基于Spring框架自研緩存解決方案,展現(xiàn)了他的專業(yè)技術(shù)能力和積極工作態(tài)度,他通過問題診斷、技術(shù)選型、編碼測試、文檔編寫和部署監(jiān)控等一系列步驟,確保了新緩存系統(tǒng)的功能正確性和性能穩(wěn)定性
    2024-10-10
  • 如何基于JAVA讀取yml配置文件指定key內(nèi)容

    如何基于JAVA讀取yml配置文件指定key內(nèi)容

    這篇文章主要介紹了如何基于JAVA讀取yml配置文件指定key內(nèi)容,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • 關(guān)于maven環(huán)境的安裝及maven集成idea環(huán)境的問題

    關(guān)于maven環(huán)境的安裝及maven集成idea環(huán)境的問題

    Maven 是一個基于 Java 的工具,所以要做的第一件事情就是安裝 JDK。本文重點給大家介紹關(guān)于maven環(huán)境的安裝及和idea環(huán)境的集成問題,感興趣的朋友一起看看吧
    2021-09-09
  • 劍指Offer之Java算法習(xí)題精講二叉樹與鏈表

    劍指Offer之Java算法習(xí)題精講二叉樹與鏈表

    跟著思路走,之后從簡單題入手,反復(fù)去看,做過之后可能會忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會發(fā)現(xiàn)質(zhì)的變化
    2022-03-03
  • Spring Cloud超詳細(xì)i講解Feign自定義配置與使用

    Spring Cloud超詳細(xì)i講解Feign自定義配置與使用

    這篇文章主要介紹了SpringCloud Feign自定義配置與使用,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 詳解如何實現(xiàn)nacos的配置的熱更新

    詳解如何實現(xiàn)nacos的配置的熱更新

    這篇文章主要為大家詳細(xì)介紹了如何實現(xiàn)nacos的配置的熱更新,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • Java基于正則表達(dá)式實現(xiàn)查找匹配的文本功能【經(jīng)典實例】

    Java基于正則表達(dá)式實現(xiàn)查找匹配的文本功能【經(jīng)典實例】

    這篇文章主要介紹了Java基于正則表達(dá)式實現(xiàn)查找匹配的文本功能,結(jié)合具體實例形式分析了java正則查找、字符串遍歷、group分組相關(guān)操作技巧,需要的朋友可以參考下
    2017-04-04
  • springboot如何獲取yml文件的自定義參數(shù)

    springboot如何獲取yml文件的自定義參數(shù)

    這篇文章主要介紹了springboot如何獲取yml文件的自定義參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 微服務(wù)搭建集成Spring Cloud Turbine詳解

    微服務(wù)搭建集成Spring Cloud Turbine詳解

    Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發(fā)便利性巧妙地簡化了分布式系統(tǒng)基礎(chǔ)設(shè)施的開發(fā),最終給開發(fā)者留出了一套簡單易懂、易部署和易維護(hù)的分布式系統(tǒng)開發(fā)工具包。下面我們來詳細(xì)了解一下吧
    2019-06-06

最新評論