首頁 > Java > java教程 > 主體

如何在 Java 中根據另一個列表的順序對一個列表進行排序?

Barbara Streisand
發布: 2024-11-02 15:46:29
原創
949 人瀏覽過

How to Sort One List Based on the Order of Another List in Java?

在Java 中根據另一個列表對一個列表進行排序

在Java 中,可以根據另一個列表的順序對一個列表進行排序。當您在一個清單 (listB) 中有特定的項目序列並且您想要重新排列第二個清單 (listA) 以符合該順序時,這可能很有用。

實現此目的的一種方法是使用具有自訂比較器的Collections.sort() 方法如下:

<code class="java">Collections.sort(listToSort, new Comparator<T>() {
    @Override
    public int compare(T o1, T o2) {
        return listWithOrder.indexOf(o1) - listWithOrder.indexOf(o2);
    }
});</code>
登入後複製

這裡,listToSort 表示未排序的列表,listWithOrder 包含所需的列表指令。此比較器根據 listWithOrder 中元素的順序對 listToSort 進行排序。

對於 Java 8 及更高版本,您可以使用 lambda 和 ComparisonInt() 方法來簡化程式碼:

<code class="java">listToSort.sort(Comparator.comparingInt(listWithOrder::indexOf));</code>
登入後複製

以上是如何在 Java 中根據另一個列表的順序對一個列表進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板