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