Steamroller

对嵌套的数组进行扁平化处理。你必须考虑到不同层级的嵌套。

思路

Array.isArray(value) 可以用来判断某个值是否为数组,是则返回 true ,不是返回 false 。

因为需要解决层级嵌套的问题,所以本题用递归来解决。

遍历 arr 的每一项,如果该项为数组,则重复调用本函数,如果不是数组,则将这一项推入结果集中。

 

function steamroller(arr) {
  // I'm a steamroller, baby 
  var result = [];
  for(var i = 0; i < arr.length; i++){
    if(Array.isArray(arr[i])){
      result = result.concat(steamroller(arr[i]));
    }else{
      result.push(arr[i]);
    }
  }
  return result;
}

 

posted @ 2016-11-29 16:43  兴趣使然的椰子  阅读(1094)  评论(0编辑  收藏  举报