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