【杂记】java 大集合进行拆分

日常中需要对一个大的集合进行拆分成多个小集合,其主要思路为:

  1. 设置需要拆分多少个小集合 A
  2. 大集合里面有多少条数据 B
  3. 计算出每个集合里面有多个条数据 C=B/A
  4. 计算出看是否存在余数 D=B%A
  5. 采用集合(List.subList())的方法对大集合进行拆分,循环A变进行集合拆分(List.subList((A-1)*C,(A-1)*C+(C-1))
  6. 如果存在余数D,则需要将剩余的数据放在一个集合中 (List.subList((AC,AC+D)

代码如下:

java 复制代码
 /**
     * 集合切分(将一个1002大小的集合,拆分为5个小集合)
     * @param list 目标集合
     * @param partitionSize 需要拆分集合的个数
     * @param <T> 泛型对象
     * @return 切分后的总的集合
     */
    public static <T> List<List<T>> listPartition(List<T> list, int partitionSize) {
        //①如果集合时空的或者初始设置的集合大小小于等于0,返回一个新集合
        if (list.isEmpty() || partitionSize <= 0) {
            return new ArrayList();
        }
        //②封装最后返回的结果集的集合
        List<List<T>> listResult = new ArrayList<>();
        int size = list.size();
        //③如果目标集合的大小小于设置集合的大小,将目标集合,全部加载到封装结果集中,返回结束
        if (size <= partitionSize) {
            listResult.add(list);
            return listResult;
        }
        //④计算出拆分的集合的大小(size =1002, partitionSize= 5  partitionNum =200 partitionRemainder=2)
        int partitionNum = size / partitionSize;
        //⑤计算出最后一个拆分集合的大小
        int partitionRemainder = size % partitionSize;
        for (int a = 1; a <= partitionSize; a++) {
            //⑥对目标集合进行截取 ((1-1)*200,((1-1)*200)+(200-1))
            List<T> ts = list.subList((a - 1) * partitionNum, ((a - 1) * partitionNum) + (partitionNum - 1));
            listResult.add(ts);
        }
        //⑦如果最后一个拆分集合的大小大于0
        if (partitionRemainder > 0) {
            //⑧对目标集合进行截取 ((200*5,200*5+2)
            List<T> ts = list.subList(partitionNum * partitionSize, partitionNum * partitionSize + partitionRemainder);
            listResult.add(ts);
        }
        //⑨返回结果集
        return listResult;
    }
相关推荐
岁忧4 分钟前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表
YuTaoShao7 分钟前
【LeetCode 热题 100】240. 搜索二维矩阵 II——排除法
java·算法·leetcode
考虑考虑1 小时前
JDK9中的dropWhile
java·后端·java ee
想躺平的咸鱼干1 小时前
Volatile解决指令重排和单例模式
java·开发语言·单例模式·线程·并发编程
hqxstudying2 小时前
java依赖注入方法
java·spring·log4j·ioc·依赖
·云扬·2 小时前
【Java源码阅读系列37】深度解读Java BufferedReader 源码
java·开发语言
Bug退退退1233 小时前
RabbitMQ 高级特性之重试机制
java·分布式·spring·rabbitmq
小皮侠3 小时前
nginx的使用
java·运维·服务器·前端·git·nginx·github
Zz_waiting.3 小时前
Javaweb - 10.4 ServletConfig 和 ServletContext
java·开发语言·前端·servlet·servletconfig·servletcontext·域对象
全栈凯哥3 小时前
02.SpringBoot常用Utils工具类详解
java·spring boot·后端