codecamp

数组分割算法挑战

方法一:

function chunk(arr, size) {
// Break it up.
var len=parseInt(arr.length/size);  
  //取模
  var remain=arr.length%size;  
  //定义各变量
  var a=[],count=1,sot=remain>0?len+1:len;   
  //装到新数组
  for ( var f = 1; f <=sot; f++) {  
    var start=size*(f-1);  
    var end=(f>len)?((f-1)*size+remain):f*size;  
    var mylocates=arr.slice(start,end);  
    a.push(mylocates);  
  }  
 return a; 
}
chunk(["a", "b", "c", "d"], 2);

方法二:

function chunk(arr, size) {
  // Break it up.
  var len = arr.length,
      m = len%size,
      div = 1,
      rArr = [];
  if(len > size){
    div = Math.floor(len/size);
    for(var i=0;i<div;i++){
      rArr.push(arr.slice(i*size,(i+1)*size));
    }
    if(m>0){
      rArr.push(arr.slice(m*(-1)));
    }
  }
  return rArr;
}

字符串截取算法挑战
数组截断算法挑战
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

HTML5&CSS

JavaScript

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }