在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中文網其他相關文章!