比较器错误java.lang.IllegalArgumentException

如何根据设置位的计数对数组进行排序?我在下面的代码中遇到错误:

Arrays.sort(arr, (o1, o2) -> {
    if (Integer.bitCount(o1) <=  Integer.bitCount(o2))
        return 1;
    return -1;
});

例外:

Exception in thread "main" java.lang.IllegalArgumentException: Comparison method violates its general contract!
    at java.base/java.util.TimSort.mergeLo(TimSort.java:781)
    at java.base/java.util.TimSort.mergeAt(TimSort.java:518)
    at java.base/java.util.TimSort.mergeCollapse(TimSort.java:448)
    at java.base/java.util.TimSort.sort(TimSort.java:245)
    at java.base/java.util.Arrays.sort(Arrays.java:1441)
    at Compute.sortBySetBitCount(File.java:44)
    at GFG.main(File.java:23)

如何解决这个问题?

回答

0即使元素相等,您也永远不会返回。Comparing.comparing对于简单的排序方法,使用这些方法通常更好。

Arrays.sort(arr, Comparator.comparingInt(Integer::bitCount).reversed());


以上是比较器错误java.lang.IllegalArgumentException的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>