之前写过的代码,几个月后遇到类似的功能,感觉很熟悉,稍微费些劲也能做到,但是觉得有些不甘。明明之前整理好的为什么要重新做?百度参考其他人的思路感觉不是很顺心,个人原因吧。于是翻箱倒柜找出以前的代码,贴在这里留作笔记,或许也有其他同行有相似需求,聊做参考。

/**
 * 数组切分
 * 
 */
public class PartitionList {
    
    /**
     * 方式一
     * 非均分,最后一组数量可能小于其它组数量
     * @param list
     * @param unitSize
     * @return
     */
    public static <T> List<List<T>> splitList_1(List<T> list, int unitSize) {
        if (list == null || list.isEmpty() || unitSize < 1)
            return null;

        int wholeSize = list.size();
        int groupNum = wholeSize / unitSize;
        List<List<T>> result = new ArrayList<List<T>>();

        for (int i = 0; i < groupNum; i++) {
            List<T> subList = list.subList(i * unitSize, (i + 1) * unitSize);
            result.add(subList);
        }
        
        if(unitSize * groupNum < wholeSize){
            List<T> restList = list.subList(unitSize * groupNum, wholeSize);
            result.add(restList);
        }
        
        return result;
    }
    
    /**
     * 方式二
     * 非均分,最后一组数量可能小于其它组数量
     * @param list
     * @param unitSize
     * @return
     */
    public static <T> List<List<T>> splitList_2(List<T> list, int unitSize) {
        if (list == null || list.isEmpty() || unitSize < 1)
            return null;

        int wholeSize = list.size();
        List<List<T>> result = new ArrayList<List<T>>();
        
        int start = 0;
        int end = 0;
        while(start < wholeSize){
            end = start + unitSize;
            if(end > wholeSize){
                end = wholeSize;
            }
            List<T> subList = list.subList(start, end);
            result.add(subList);
            start = start + unitSize;
        }
        return result;
    }
}

当然,这里面也是有参考其他大拿思路的地方,自己稍作了些改动。

百度过程中发现有人提到guava,appache ListUtil,java8新特性均可切分List,在这里Mark一下。