玖叶教程网

前端编程开发入门

将数组扁平化并去除其中的重复数据,最终得到一个升序的新数组

已知如下数组:

var arr = [ [1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14] ] ] ], 10];

将数组扁平化并去除其中的重复数据,最终得到一个升序的新数组。

分析

其实题目包含三个要求:

1.扁平化;

2.去重;

3.排序;

弄清楚题目的要求之后,就可以分别从这三个方面入手了。如果利用ES6的特性,依次利用flat(Infinity)打平,Set去重和sort排序就好了。

方法一

Array.from(new Set(arr.flat(Infinity))).sort((a,b)=>{ return a-b})

解释:

①flat()默认只会“拉平”一层,如果想要“拉平”多层的嵌套数组,可以将flat()方法的参数写成一个整数,表示想要拉平的层数,默认为1。

[1, 2, [3, [4, 5]]].flat() // [1, 2, 3, [4, 5]]
[1, 2, [3, [4, 5]]].flat(2) // [1, 2, 3, 4, 5]

上面代码中,flat()的参数为2,表示要“拉平”两层的嵌套数组。

如果不管有多少层嵌套,都要转成一维数组,可以用Infinity关键字作为参数。

[1, [2, [3]]].flat(Infinity) // [1, 2, 3]

②new Set()得到一个元素唯一的类数组结构。

③Array.from()把类数组变成真正的数组。

④sort(),排序。

方法二(原理一样):

Array.prototype.flat= function() {
 return [].concat(...this.map(item => (Array.isArray(item) ? item.flat() : [item])));
}

Array.prototype.unique = function() {
 return [...new Set(this)]
}

const sort = (a, b) => a - b;

arr.flat().unique().sort(sort);

欢迎关注

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言