用 java 写:将一个List<Integer>排序后分割,连续的分成一组
时间: 2024-03-16 12:42:20 浏览: 53
您好,以下是将一个 `List<Integer>` 排序后分割,连续的分成一组的 Java 代码:
```java
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class Main {
public static void main(String[] args) {
List<Integer> list = new ArrayList<>(Arrays.asList(1, 3, 2, 6, 5, 7, 8, 9, 10));
list.sort(Integer::compareTo);
List<List<Integer>> result = new ArrayList<>();
List<Integer> temp = new ArrayList<>();
for (int i = 0; i < list.size(); i++) {
if (temp.isEmpty() || list.get(i) == temp.get(temp.size() - 1) + 1) {
temp.add(list.get(i));
} else {
result.add(temp);
temp = new ArrayList<>();
temp.add(list.get(i));
}
}
result.add(temp);
System.out.println(result);
}
}
```
首先创建一个 `List<Integer>` 对象并初始化,然后使用 `sort` 方法对其进行排序。接着创建 `List<List<Integer>>` 对象用来存储分割后的结果,以及一个 `List<Integer>` 用来存储当前连续的一组数。然后使用 `for` 循环遍历排序后的列表,如果当前元素是连续的,则将其加入到 `temp` 列表中,否则将 `temp` 列表加入到 `result` 列表中,并重新创建一个空的 `temp` 列表来存储下一个连续的一组数。循环结束后,将最后一个 `temp` 列表加入到 `result` 列表中即可。
输出结果为:`[[1, 2, 3], [5, 6, 7, 8, 9, 10]]`
阅读全文