js深拷贝、数组扁平化(数组展平)

深拷贝

function dc(o){
	let newObj=Array.isArray(o)?[]:{}
	for(k in o){ 
		if(o[k] instanceof Array||o[k] instanceof Object){ 
            newObj[k]=dc(o[k])
        }
        else newObj[k]=o[k]
	}
    return newObj
}

数组扁平

//不带层数,全展平
const fn1=(arr)=>{
    return arr.reduce((flatArr,it)=>{
        return flatArr.concat(Array.isArray(it)?fn1(it):it)
    },[])
}
//带层数展平
const fn=(arr,l)=>{
    if(l<=0)return arr
    return arr.reduce((flatArr,it)=>{
        return flatArr.concat(Array.isArray(it)?fn(it,l-1):it)
    },[])
}
const array = [1, [2, [3, [4, [5]]]]];
const flatArray = fn(array,1); // [1, 2, [3, [4, [5]]]]
console.log(flatArray)
var arr=[1,[2,3],[4,[5,[6]]]]
var narr=[]
function fn(arr){
  if(!arr)return
  for(it of arr){
    if(Array.isArray(it))fn(it)
    else{
      narr.push(it)
    }
  }
}
fn(arr)
console.log(narr)

数组去重

var arr=[1,2,1,3,2]
var set=new Set(arr)
console.log([...set])

并交差集

var arr=[1,2,1,3,2],arr1=[1,4]

// 并集
let union=new Set([...a,...b])
// 交集
let intersect=new Set([...a].filter(x=>b.includes(x)))
// 差集
let difference=new Set([...a].filter(x=>!b.includes(x)))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值