前端面试手写代码——JS数组去重

技术前端面试手写代码——JS数组去重 前端面试手写代码——JS数组去重JavaScript 数组去重类型总结,4大类型,8种基础写法1 测试用例
// 测试用例
const a = {};
const

前端面试手写代码——JS数组重复。

JavaScript中阵列重复数据消除类型总结,4种类型,8种基本编写方法。

1 测试用例

//测试用例

const a={ };

const b={ c : 1 };

常量数组=[

1, 1, '1', '1',

{}、{}、{ c: 1 }、{ c: 1},

a,a,b,b,

[], [], [1], [1],

未定义,未定义,

空,空,

NaN,NaN,

];

2 JS 数组去重4大类型

2.1 元素比较型

通过数组元素之间的比较,此类型被复制。

2.1.1 双层 for 循环逐一比较(es5常用)

使用双层for循环逐个比较数组元素,使用拼接方法去除重复元素。

//双层用于循环。

函数uniq 1(arr){ 0

for(设I=0;一、长度;I){ 0

for(设j=I ^ 1;j arr.lengthj ) {

if (arr[i]===arr[j])

arr.splice(j,1)

j -

}

}

}

返回逮捕

}

//重复删除结果

//[1,' 1 ',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],未定义,null,NaN,NaN]

通过比较重复数据消除前后的结果,不会删除重复的NaN,因为NaN===NaN为假。

2.1.2 排序相邻比较

使用sort()方法对数组元素进行排序,然后比较相邻的元素,并使用splice方法删除重复的元素。

函数uni2(arr){ 0

arr . sort();

for(设I=0;I arr . length-1;I){ 0

arr[i]===arr[i 1] arr.splice(i 1,1)I-;

}

返回逮捕;

}

您还可以创建一个新数组,并将非重复元素放入新数组中。

函数uniq 3(arr){ 0

arr=arr.sort()

const newArr=[arr[0]]

for(设I=1;一、长度;I){ 0

如果!==arr[i - 1]) {

推(arr[i])

}

}

返回纽约

}

//重复删除结果

//[[],[],1,' 1 ',[1],[1],NaN,NaN,{},{},{c:1},{c:1},{},{c:1},null,未定义]

的重复NaN未被删除,因为NaN===NaN为假。

排序的默认排序顺序是将元素转换为字符串,所有从对象转换而来的字符串都是[object Object],所以排序方法无法对数组中的对象进行排序,有可能重复的对象无法移除,除非重复的对象相邻。

2.2 查找元素位置型

通过查找元素的第一个匹配项来复制该类型。

2.2.1 indexOf

通过indexOf查找当前元素第一次出现的位置是否是当前位置,如果是,将其放入新数组中。

函数uniq 4(arr){ 0

让res=[]

for(设I=0;一、长度;I){ 0

if(arr . indexof(arr[I])===I){ 0

res.push(arr[i])

}

}

返回资源

}

//重复删除结果

//[1,' 1 ',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],undefin

ed,null]

同样,因为NaN === NaNfalse,所以用indexOf查找NaN结果总是-1,从而在新数组中不会有NaN

2.2.2 findIndex

通过findIndex查找当前元素第一次出现的位置是否为当前位置,若是,则放入新数组

function uniq5(arr) {
    let res = []
    for (let i = 0; i  arr.length; i++) {
        if (arr.findIndex(item = item === arr[i]) === i) {
            res.push(arr[i])
        }
    }
    return res
}
// 去重结果
// [1,'1',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],undefined,null]

同样,因为NaN === NaNfalse,所以用findIndex查找NaN结果总是-1,从而在新数组中不会有NaN

2.3 元素是否存在型

此类型通过判断在新数组中是否存在当前元素来去重

2.3.1 includes

includes方法用来判断一个数组是否包含一个指定的值

function uniq6(arr) {
    let res = []
    for (let i = 0; i  arr.length; i++) {
        if (!res.includes(arr[i])) {
            res.push(arr[i])
        }
    }
    return res
}
// 去重结果
// [1,'1',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],undefined,null,NaN]

includes使用零值相等算法来确定是否找到给定的元素,所以可以判断NaN是否在新数组中存在

2.3.2 some

some方法用来测试数组中是否至少有1个元素通过了被提供的函数测试

function uniq7(arr) {
    let res = []
    for (let i = 0; i  arr.length; i++) {
        if (!res.some(item = item === arr[i])) {
            res.push(arr[i])
        }
    }
    return res
}
// 去重结果
// [1,'1',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],undefined,null,NaN,NaN]

同样,这里仍旧使用了===来比较元素,因为NaN === NaNfalse,所以新数组中会有多个NaN

2.4 依托数据结构特性

此类型通过ES6提供的数据结构MapSet本身不可重复特性来去重

2.4.1 Map

ES6提供的Map结构可以用各种类型的值(包括对象)当作键,且键是唯一的

function uniq8(arr) {
    const map = new Map()
    for (let i = 0; i  arr.length; i++) {
        !map.has(arr[i])  map.set(arr[i], true)
    }
    return [...map.keys()]
}
// 去重结果
// [1,'1',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],undefined,null,NaN]

map.has方法对NaN也有效

2.4.2 Set(ES6 最常用)

Set结构的成员的值都是唯一的,没有重复的值。

function uniq9(arr) {
    return [...new Set(arr)]
}
// 去重结果
// [1,'1',{},{},{c:1},{c:1},{},{c:1},[],[],[1],[1],undefined,null,NaN]

3 补充

  1. 上面所说的方法可以使用不同的Api进行改动,比如使用splice方法去除数组元素的地方,我们可以通过filter方法来过滤数组得到新数组;

    再比如includes的方法中不用for循环遍历数组,通过reduce方法来代替等等。

    总之,方法有很多,但是万变不离其宗

  2. 有些去重方法对NaN无效,因为NaN === NaNfalse,如果有需求,可以使用Object.is(NaN, NaN)true来进行修改

  3. 实际应用中,最常用的方法就是使用Set,也可以使用第三方库lodash来处理

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/36333.html

(0)

相关推荐

  • C++实现WPF动画的具体操作方法

    技术C++实现WPF动画的具体操作方法本篇文章为大家展示了C++实现WPF动画的具体操作方法,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。C++编程语言的应方式非常广泛,可以帮助

    攻略 2021年10月27日
  • dya 2.c++语法

    技术dya 2.c++语法 dya 2.c++语法构造函数 用途:用来初始化类对象的数据成员; 构造函数和类名相同,没有返回值,可以有多个构造函数 不同的构造函数形参数量或者类型要有所区别

    礼包 2021年12月2日
  • 大于小于号怎么用,一年级数学的大于号小于号怎么分

    技术大于小于号怎么用,一年级数学的大于号小于号怎么分大于号小于号的区分方法:尖角向左的是小于号,尖角向右的是大于号大于小于号怎么用。 1、大于号、小于号被广泛运用在算数中,是小学必学的内容。是数学中不等式运算符号的一种。

    生活 2021年10月25日
  • IP代理软件怎么助力新媒体增长

    技术IP代理软件怎么助力新媒体增长小编给大家分享一下IP代理软件怎么助力新媒体增长,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、在各种方式

    攻略 2021年11月1日
  • 求圆的面积公式,用直径计算圆面积的公式

    技术求圆的面积公式,用直径计算圆面积的公式圆用直径算面积公式:S=πd²/4其中:S表示圆的面积求圆的面积公式,d表示圆的直径;圆的概念1.到定点的距离等于定长的点的集合叫做圆。这个定点叫做圆的圆心,通常用字母“o”表示

    生活 2021年10月23日
  • hadoop运行环境配置(如何配置hadoop基础环境)

    技术如何搭建hadoop运行环境这篇文章主要介绍如何搭建hadoop运行环境,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! Hadoop作为搭建大数据处理平台的重要“基石”,关于它的分析和讲解的文

    攻略 2021年12月20日