package com.test;
import java.util.ArrayList;
import java.util.List;
public class ListSplit {
/**
* 1> 按照份数---划分list
* @param source
* @param num 想要划分成多少份
* @return
*/
public static List> splitListForNum(List source,int num){
List> result=new ArrayList>();
int remaider=source.size()%num; //(先计算出余数)
int number=source.size()/num; //然后是商
int offset=0;//偏移量
for(int i=0;i
List value=null;
if(remaider>0){
value=source.subList(i*number+offset, (i+1)*number+offset+1);
remaider--;
offset++;
}else{
value=source.subList(i*number+offset, (i+1)*number+offset);
}
result.add(value);
}
return result;
}
/**
* 2> 根据目标容量 划分List
* @param source
* @param capacity 划分完成的单个List容量
* @param
* @return
*/
public static List> splitListBycapacity(List source,int capacity){
List> result=new ArrayList>();
if (source != null){
int size = source.size();
if (size > 0 ){
for (int i = 0; i
List value = null;
int end = i+capacity;
if (end > size){
end = size;
}
value = source.subList(i,end);
i = end;
result.add(value);
}
}else {
result = null;
}
}else {
result = null;
}
return result;
}
public static void main(String[] args) {
List all = new ArrayList<>();
int a= 1000;
for (int i = 0; i
all.add(i+1);
}
List> split = splitListBycapacity(all,333);
System.out.println(split.size());
for (List strings : split) {
System.out.println(strings.size());
}
}
}