用 java 写:将一个List<Integer>排序后分割,连续的分成一组,每组元素数量不超过100
时间: 2024-03-16 18:42:24 浏览: 128
您好,以下是将一个 `List<Integer>` 排序后分割,连续的分成一组,每组元素数量不超过100 的 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++) {
temp.add(list.get(i));
if (i == list.size() - 1 || temp.size() == 100 || list.get(i + 1) != list.get(i) + 1) {
result.add(temp);
temp = new ArrayList<>();
}
}
System.out.println(result);
}
}
```
与上一个问题的代码相似,只需要增加一个判断条件来判断当前组的元素数量是否超过 100。如果超过,则将当前组加入到 `result` 列表中,并重新创建一个空的 `temp` 列表来存储下一个连续的一组数。循环结束后,将最后一个 `temp` 列表加入到 `result` 列表中即可。
输出结果为:`[[1, 2, 3], [5, 6, 7, 8, 9, 10]]`
阅读全文