package com.micro.order.util;
import com.google.common.collect.Lists;
import java.util.ArrayList;
import java.util.List;
public class ListSplitUtil<T extends Object> {
public static <T> List<List<T>> splitSize(List<T> list, int size) {
if (list == null || list.size() == 0) {
return null;
}
int count = list.size();
int pageCount = (count / size) + (count % size == 0 ? 0 : 1);
List<List<T>> temp = new ArrayList<>(pageCount);
for (int i = 0, from = 0, to = 0; i < pageCount; i++) {
from = i * size;
to = from + size;
to = to > count ? count : to;
List<T> list1 = list.subList(from, to);
temp.add(list1);
}
return temp;
}
public static <T> List<List<T>> splitNum(List<T> list, int sum) {
if (list == null || list.size() == 0) {
return null;
}
if (list.size() < sum) {
return null;
}
int count = list.size();
int pageCount = (count / sum);
int countTemp = count % sum;
int lastSize = pageCount;
if (countTemp != 0) {
lastSize = pageCount + countTemp;
}
List<List<T>> temp = new ArrayList<>(pageCount);
for (int i = 0, from = 0, to = 0; i < sum; i++) {
from = i * pageCount;
to = from + pageCount;
List<T> list1 = Lists.newArrayList();
if (i == (sum - 1)) {
list1 = list.subList(from, list.size());
} else {
list1 = list.subList(from, to);
}
temp.add(list1);
}
return temp;
}
public static void main(String[] args) {
List<Integer> list = new ArrayList<>();
for (int i = 0; i < 52; i++) {
list.add(i);
}
List<List<Integer>> split = splitNum(list, 3);
for (int i = 0, length = split.size(); i < length; i++) {
System.out.println(split.get(i));
}
}
}