Java将List平均分成多少份或者按照指定大小进行分割

前言:此方法其实就是将一个列表按照指定份数或者指定大小对数据列表进行分割,如果不能整除则会将剩余的放到最后一个数组

1. 将List平均分成多少份

/**
 * 将List平均分成多少份
 *
 * @param list  数据列表
 * @param parts 份数
 * @param <T>
 * @return
 */
public static <T> List<List<T>> splitListForParts(List<T> list, int parts) {
    List<List<T>> res = new ArrayList<>();
    // 总数
    int total = list.size();
    // 计算每份多少个, 下面两种写法效果一致
    int chunkSize = (total + parts - 1) / parts; // 向下取整
    //int chunkSize = total % parts == 0 ? total / parts : total / parts + 1;

    // 第一种写法
    for (int i = 0; i < total; i += chunkSize) {
        // 计算end的大小, 如果大于总数则取总数, 下面两种写法效果一致
        //int end = i + chunkSize > total ? total : i + chunkSize;
        int end = Math.min(i + chunkSize, total);
        res.add(list.subList(i, end));
    }
    return res;
}

2. 将List按照每份指定的大小进行分割

/**
 * 将List按照每份指定的大小进行分割
 *
 * @param list      数据列表
 * @param chunkSize 每份的大小
 * @param <T>
 * @return
 */
public static <T> List<List<T>> splitListForChunkSize(List<T> list, int chunkSize) {
    List<List<T>> res = new ArrayList<>();
    // 总数
    int total = list.size();
    // 如果每份的大小大于或等于总数则直接返回
    if (chunkSize >= total) {
        res.add(list);
        return res;
    }

    // 第二种写法
    int page = 0;
    while (true) {
        int start = page * chunkSize;
        int end = (page + 1) * chunkSize;
        // 如果end大于total则说明是最后一页
        if (end > total) {
            if (start < total) {
                res.add(list.subList(start, total));
            }
            break;
        }

        // 非最后一页正常获取
        res.add(list.subList(start, end));

        // 页码每次加1
        page += 1;
    }
    return res;
}

3. 完整代码示例以及测试

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;

public class ListTest {

    /**
     * 将List平均分成多少份
     *
     * @param list  数据列表
     * @param parts 份数
     * @param <T>
     * @return
     */
    public static <T> List<List<T>> splitListForParts(List<T> list, int parts) {
        List<List<T>> res = new ArrayList<>();
        // 总数
        int total = list.size();
        // 计算每份多少个, 下面两种写法效果一致
        int chunkSize = (total + parts - 1) / parts; // 向下取整
        //int chunkSize = total % parts == 0 ? total / parts : total / parts + 1;

        // 第一种写法
        for (int i = 0; i < total; i += chunkSize) {
            // 计算end的大小, 如果大于总数则取总数, 下面两种写法效果一致
            //int end = i + chunkSize > total ? total : i + chunkSize;
            int end = Math.min(i + chunkSize, total);
            res.add(list.subList(i, end));
        }

//        // 第二种写法
//        int page = 0;
//        while (true) {
//            int start = page;
//            int end = page + chunkSize;
//            // 如果end大于total则说明是最后一页
//            if (end > total) {
//                if (start < total) {
//                    res.add(list.subList(start, total));
//                }
//                break;
//            }
//
//            // 非最后一页正常获取
//            res.add(list.subList(start, end));
//
//            // 页码加每份的大小
//            page += chunkSize;
//        }

//        // 第三种写法
//        int page = 0;
//        while (true) {
//            int start = page * chunkSize;
//            int end = (page + 1) * chunkSize;
//            // 如果end大于total则说明是最后一页
//            if (end > total) {
//                if (start < total) {
//                    res.add(list.subList(start, total));
//                }
//                break;
//            }
//
//            // 非最后一页正常获取
//            res.add(list.subList(start, end));
//
//            // 页码每次加1
//            page += 1;
//        }

        return res;
    }

    /**
     * 将List按照每份指定的大小进行分割
     *
     * @param list      数据列表
     * @param chunkSize 每份的大小
     * @param <T>
     * @return
     */
    public static <T> List<List<T>> splitListForChunkSize(List<T> list, int chunkSize) {
        List<List<T>> res = new ArrayList<>();
        // 总数
        int total = list.size();
        // 如果每份的大小大于或等于总数则直接返回
        if (chunkSize >= total) {
            res.add(list);
            return res;
        }

//        // 第一种写法
//        for (int i = 0; i < total; i += chunkSize) {
//            // 计算end的大小, 如果大于总数则取总数, 下面两种写法效果一致
//            //int end = i + chunkSize > total ? total : i + chunkSize;
//            int end = Math.min(i + chunkSize, total);
//            res.add(list.subList(i, end));
//        }

        // 第二种写法
        int page = 0;
        while (true) {
            int start = page * chunkSize;
            int end = (page + 1) * chunkSize;
            // 如果end大于total则说明是最后一页
            if (end > total) {
                if (start < total) {
                    res.add(list.subList(start, total));
                }
                break;
            }

            // 非最后一页正常获取
            res.add(list.subList(start, end));

            // 页码每次加1
            page += 1;
        }

        return res;
    }


    public static void main(String[] args) {
        int total = 500;
        List<Integer> numbers = new LinkedList<>();
        for (int i = 1; i < total; i++) numbers.add(i);

        // 将列表平均分成7份
        List<List<Integer>> parts = splitListForParts(numbers, 7);
        parts.forEach(System.out::println);
        System.out.println("----------------splitListForParts 将List平均分成多少份结束");

        // 将列表按照每份133的大小进行分割
        List<List<Integer>> chunkSize = splitListForChunkSize(numbers, 133);
        chunkSize.forEach(System.out::println);
        System.out.println("----------------splitListForChunkSize 将List按照每份指定的大小进行分割");
    }

}
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 Java 中的 sublist 方法将 List多个子 List。具体实现可以参考以下代码: ``` public static <T> List<List<T>> splitList(List<T> list, int size) { List<List<T>> result = new ArrayList<>(); int count = (list.size() + size - 1) / size; for (int i = ; i < count; i++) { int fromIndex = i * size; int toIndex = Math.min((i + 1) * size, list.size()); result.add(list.subList(fromIndex, toIndex)); } return result; } ``` 其中,list 表示要分割List,size 表示每个子 List大小。该方法返回一个 List,其中每个元素都是一个子 List。 ### 回答2: 在Java中,可以通过以下方式将List为多个子列表。 首先,确定每个子列表的大小,即每个子列表中元素的个数。可以通过计算List大小除以子列表的个数来得到这个值。 然后,通过循环迭代的方式将List中的元素按照确定的每个子列表的大小进行分割。可以使用List的subList方法来截取对应大小的子列表。 下面是一个示例代码: ```java import java.util.ArrayList; import java.util.List; public class ListPartitioning { public static void main(String[] args) { List<Integer> list = new ArrayList<>(); // 假设有一个大小为10的List for (int i = 1; i <= 10; i++) { list.add(i); } // 假设要将List3 int partitionSize = list.size() / 3; List<List<Integer>> partitions = new ArrayList<>(); int fromIndex = 0; int toIndex = partitionSize; // 循环迭代分割List并添加到子列表中 for (int i = 0; i < 3; i++) { if (i == 2) { toIndex = list.size(); // 最后一可能不够,将toIndex设为List的末尾 } List<Integer> partition = list.subList(fromIndex, toIndex); partitions.add(partition); fromIndex = toIndex; toIndex += partitionSize; } // 打印结果 for (List<Integer> partition : partitions) { System.out.println(partition); } } } ``` 以上代码将一个大小为10的List为3个子列表,结果如下: [1, 2, 3] [4, 5, 6] [7, 8, 9, 10] ### 回答3: 要将一个List多个子List,可以使用以下方法: 1. 获取原始List大小,假设为totalSize。 2. 定义子List大小,假设为subListSize。 3. 计算需要的子List数量,假设为subListCount,可以使用Math.ceil(totalSize / subListSize)来得到向上取整的结果。 4. 创建一个新的ArrayList来存储所有子List,假设为resultList。 5. 根据subListCount,循环subListCount次来创建子List: 1. 计算当前子List的起始索引,假设为start。 2. 计算当前子List的结束索引,假设为end。当达到最后一个子List时,结束索引为totalSize。 3. 使用List的subList方法,将原始List的[start, end)区间的元素作为一个新的子List,并将其添加到resultList中。 6. 返回resultList作为分割好的子List集合。 下面是一个示例代码: ```java import java.util.ArrayList; import java.util.List; public class ListPartition { public static List<List<Integer>> partitionList(List<Integer> originalList, int subListSize) { int totalSize = originalList.size(); int subListCount = (int) Math.ceil((double) totalSize / subListSize); List<List<Integer>> resultList = new ArrayList<>(); for (int i = 0; i < subListCount; i++) { int start = i * subListSize; int end = Math.min(start + subListSize, totalSize); List<Integer> subList = originalList.subList(start, end); resultList.add(subList); } return resultList; } public static void main(String[] args) { List<Integer> originalList = new ArrayList<>(); originalList.add(1); originalList.add(2); originalList.add(3); originalList.add(4); originalList.add(5); List<List<Integer>> partitionedList = partitionList(originalList, 2); for (List<Integer> subList : partitionedList) { System.out.println(subList); } } } ``` 以上示例代码将会把原始List [1, 2, 3, 4, 5] 两个子List [1, 2] 和 [3, 4, 5],并打印出来。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值