簡體   English   中英

如何使用每行的lambda /流對2D列表進行排序?

[英]How can I sort a 2D List using lambdas/streams per row?

我有一個矩陣,我想知道是否有任何方法可以對每一行進行排序,我已經嘗試過遍歷ArrayList並在每一行中對每個元素進行比較來對其進行手動排序,但這似乎很乏味。 有什么更好的辦法讓我對它進行排序。 我正在考慮使用lambda /流

我有以下字符串列表,

List<List<String>> matrix = new ArrayList<List<String>>();

假設矩陣包含ff:

sad,eat,air,vice,ride
cash,grade,save,hide,are
twin,grid,goose,hey,shade

排序后的輸出為:

air,eat,ride,sad,vice
are,cash,grade,hide,save
goose,grid,hey,shade,twin

通過使用循環和比較器按我想要的方式對其進行排序,從而解決了我的問題。 這是代碼:

for (List<String> row : matrix) {
                row.sort(Comparator.comparing(r -> r.getString()));
}

嘗試這個。

matrix.forEach(row -> Collections.sort(row));

您可以將forEach()用於主列​​表,將sort()用於每個子列表:

matrix.stream().forEach(m -> {
    System.out.print(m.stream().sorted().collect(Collectors.joining(", ")));
    System.out.println();
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM