0%

算法手写题

题目

已知如下数组:
var arr = [[1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14]]]], 10];
编写一个程序将数组扁平化去并除其中重复部分数据,最终得到一个升序且不重复的数组

个人题解

  • 递归;

    不想写

  • while循环遍历

    不想写

  • Array.prototype.flat

    1
    2
    3
    4
    5
    var arr = [[1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14]]]], 10];
    function arrayFlat(arr) {
    return Array.from(new Set(arr.flat(Infinity))).sort((a,b)=>{ return a-b});
    }
    arrayFlat(arr) //
  • 骚操作

    1
    2
    3
    4
    5
    var arr = [[1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14]]]], 10];
    function saocaozuo(arr) {
    return [...new Set(arr.toString().split(","))].sort((a, b) => a - b);
    }
    saocaozuo(arr) //

相关链接

第 11 题:将数组扁平化并去除其中重复数据,最终得到一个升序且不重复的数组
Array.prototype.flat() MDN