91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在java中使用Comparator方法

發布時間:2021-01-12 16:32:08 來源:億速云 閱讀:264 作者:Leah 欄目:編程語言

怎么在java中使用Comparator方法?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

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

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

那這樣到底構造的是最大優先還是最小優先隊列呢?

看看源碼

看看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,分別執行對象判空和容量判斷
2)執行siftUp(i, e),i是原有隊列長度,e是要入隊的元素。

siftUp是堆中調整元素位置的一種方法,可以看出這里的優先隊列是使用最大/最小堆實現的。接著看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,表示最后一個非葉子節點的位置
3)e為父節點,x是入隊元素,x可以看做放在最后一個位置。如果compare(x, e) < 0,則執行元素往上走的方法。
注:在siftUp中,如果是最小堆,那么應該是較小的元素往上走,如果是最大堆,則應該是較大的元素往上走。

由于源碼中新入隊元素x是在第1個參數的位置,因此最大/最小優先隊列主要根據第1個參數的大小關系來判斷。

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

結論:

// 最小優先隊列,直接 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); */
 }
});
// 最大優先隊列,則反過來 return o2.compareTo(o1);

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

凯里市| 江油市| 门头沟区| 台山市| 四会市| 米易县| 保康县| 长泰县| 大田县| 彭水| 应城市| 五大连池市| 册亨县| 卫辉市| 察哈| 长丰县| 独山县| 安达市| 西畴县| 白银市| 三台县| 田阳县| 伊吾县| 奎屯市| 天气| 浑源县| 牙克石市| 黄山市| 绥滨县| 宜兴市| 阿鲁科尔沁旗| 荔波县| 万盛区| 胶州市| 望江县| 武乡县| 涿鹿县| 古蔺县| 正蓝旗| 宁强县| 星子县|