/**
* 集合平均切割
*
* @param source 源集合
* @param n 分成n个集合
* @param <T> 集合类型
* @return
*/
public <T> List<List<T>> averageAssign(List<T> source, int n) {
List<List<T>> lists = Lists.newArrayList();
int number = source.size() / n;
int remaider = source.size() % n;
int offset = 0;
for (int i = 0; i < n; i++) {
List<T> list1 = null;
if (remaider > 0) {
list1 = source.subList(i * number + offset, (i + 1) * number + offset + 1);
remaider--;
offset++;
} else {
list1 = source.subList(i * number + offset, (i + 1) * number + offset);
}
lists.add(list1);
}
return lists;
}