參加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;
}
測試後發現該方法是可行的。