java優(yōu)先隊(duì)列自定義排序的方法是什么

小億
126
2023-09-07 14:14:35

Java中的優(yōu)先隊(duì)列(PriorityQueue)默認(rèn)使用元素的自然順序進(jìn)行排序。如果想自定義排序規(guī)則,需要通過(guò)實(shí)現(xiàn)Comparator接口來(lái)定義。

實(shí)現(xiàn)Comparator接口的方式有兩種:

  1. 創(chuàng)建一個(gè)新的類,讓該類實(shí)現(xiàn)Comparator接口,并重寫(xiě)compare方法。然后在PriorityQueue的構(gòu)造函數(shù)中傳入該類的實(shí)例。

例如:

class MyComparator implements Comparator<Integer> {
@Override
public int compare(Integer a, Integer b) {
// 自定義排序規(guī)則,例如按照元素的絕對(duì)值進(jìn)行排序
return Integer.compare(Math.abs(a), Math.abs(b));
}
}
PriorityQueue<Integer> pq = new PriorityQueue<>(new MyComparator());
  1. 使用匿名類的方式實(shí)現(xiàn)Comparator接口并重寫(xiě)compare方法。

例如:

PriorityQueue<Integer> pq = new PriorityQueue<>(new Comparator<Integer>() {
@Override
public int compare(Integer a, Integer b) {
// 自定義排序規(guī)則,例如按照元素的絕對(duì)值進(jìn)行排序
return Integer.compare(Math.abs(a), Math.abs(b));
}
});

以上兩種方式都是通過(guò)實(shí)現(xiàn)Comparator接口來(lái)自定義排序規(guī)則。在compare方法中,返回負(fù)數(shù)表示a排在b前面,返回正數(shù)表示a排在b后面,返回0表示a和b相等。根據(jù)compare方法的返回值來(lái)確定優(yōu)先隊(duì)列中元素的順序。

0