参加web前端笔试的时候的一道题,大意是一个数组arr和一个数字n,j经过函数function arrSort(){}处理后有返回一个result;result满足下面的要求:当arr=[1,2,3,4,],n=2,result=[[1,2],[3,4]];
当arr=[1,2,3,4,5],n=2,result=[[1,2],[3,4],[5]];
当arr=[1,2,3,4],n<=1,时 result=[1,2,3,4,5];
当arr=[1,2,3,4],n>arr.length,时 result=[[1,2,3,4,5]];
且arr不被修改。
笔试时,忘了splice会修改原数组了,所以出了错。
在这里修改一下,给出我的方法。
function arrSort(arr,n){
var len=arr.length;
var result=[];
var m=len%n;//求余
if(n<=1){
return result=arr;
}else if(n>len){
result[0]=arr;
return result;
}
if(m==0){
m=len/n;
for(var i=0;i<m;i++){
result[i]=arr.slice(i*n,n*(i+1));
}
}else{
m=(len-m)/n;
for(var i=0;i<m+1;i++){
result[i]=arr.slice(i*n,n*(i+1));
}
}
return result;
}
测试后发现该方法是可行的。