【算法】把数组拍平

18 篇文章 2 订阅
10 篇文章 1 订阅

concat方法创建一个新的数组

  • Array.prototype.concat.call([], …arr)

  • Array.prototype.concat.apply([], arr)

  • [].concat()

该数组由被调用数组参数元素组成。
如果参数是数组,而数组本身的元素中也包含数组,则元素数组不会被递归展开

let arr = [1,2,[3,4],5,6]
let arr3 = [].concat(arr) // [1, 2, Array(2), 5, 6]
let arr3 = [].concat(1,2,[3,4],5,6) // [1,2,3,4,5,6]

如果参数是对象,那么新数组中的元素只是参数对象的浅拷贝

let arr = [1,2,{a:3}]
let arr1 = [].concat(arr)
arr[2].a = 5
arr1 // [1,2,{a:5}]

如果参数是字符串、数字或布尔值,则该方法将这些值复制到新数组中。

[].concat(3,‘abc’, true) // [3, ‘abc’, true]

所以这里我们使用递归来实现深层数组的拍平

function flat(arr) {
	// 判断数组元素中是否还有数组类型项
    const isDeep = arr.some(item => item instanceof Array) 
    // 没有直接返回当前数组,结束递归
    if(!isDeep) {
        return arr
    }
	// 每次都把当前层数组拍平
    const res = Array.prototype.concat.apply([], arr)
    return flat(res)
    // return falt(res.sort((a, b) => a-b)) // 如果要进行排序操作
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值