Java 对 List<List<Integer>> 自定义规则排序
时间: 2023-07-09 21:16:47 浏览: 100
JAVA8 List<List<Integer>> list中再装一个list转成一个list操作
5星 · 资源好评率100%
要对 `List<List<Integer>>` 进行自定义规则排序,可以使用 `Comparator` 接口来实现。
假设我们要按照列表中第一个元素的大小进行排序,如果第一个元素相同,则按照第二个元素的大小进行排序,以此类推。
可以使用如下代码来实现:
```java
List<List<Integer>> list = new ArrayList<>();
// 假设已经将列表添加到 list 中
// 按照列表中第一个元素的大小进行排序,如果第一个元素相同,则按照第二个元素的大小进行排序,以此类推
Collections.sort(list, new Comparator<List<Integer>>() {
@Override
public int compare(List<Integer> o1, List<Integer> o2) {
for (int i = 0; i < Math.min(o1.size(), o2.size()); i++) {
int cmp = o1.get(i).compareTo(o2.get(i));
if (cmp != 0) {
return cmp;
}
}
return Integer.compare(o1.size(), o2.size());
}
});
```
这段代码使用了匿名内部类来实现 `Comparator` 接口,并重写了 `compare` 方法来定义排序规则。在 `compare` 方法中,首先遍历两个列表中的元素,按照顺序进行比较,如果发现两个元素不相同,则返回它们之间的比较结果。如果遍历完两个列表后,发现它们的长度不同,则返回它们长度之间的比较结果。最终,使用 `Collections.sort()` 方法对列表进行排序。
阅读全文