码迷,mamicode.com
首页 > 其他好文 > 详细

Steamroller

时间:2016-11-29 16:50:17      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:这一   amr   app   递归   log   集中   遍历   重复   ret   

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

思路

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;
}

 

Steamroller

标签:这一   amr   app   递归   log   集中   遍历   重复   ret   

原文地址:http://www.cnblogs.com/fffangrui/p/6114209.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!