• 数组去重的六种方法


    数组去重在面试和工作中都是比较容易见到的问题,这几天在复习基础知识的时候,也顺便总结了一下常见的方法,和大家一起分享。如果大家还有其他什么方法还请评论大家一起讨论。如果有什么没有表达正确的地方还请大家斧正。

    001、使用双重for循环

    要比较数组中的每一个值我们都可以用双重for循环来解决,比如冒泡排序。同样也可以使用双重for循环来数组去重。

    1. function unique(arr) {
    2. for (leti = 0; i < arr.length; i++) {
    3. for (let j = i+1; j < arr.length; j++) {
    4. if (arr[i] == arr[j]) {
    5. arr.splice(j,1)
    6. j--
    7. }
    8. }
    9. }
    10. return arr
    11. }
    12. let arr = [1,1,'true','true', 'a', 'a',true,true,false,false, undefined,undefined, null,null, NaN, NaN,'NaN','NaN', 0, 0,{},{},[],[]];
    13. console.log(unique(arr)) // [ 1, 'true', 'a', false, undefined, NaN, NaN, 'NaN', {}, {} ]
    14. 复制代码

    可以看见NaN没有被去除掉,两个{}都没去掉,因为{}是引用值,而却我们使用的是arr[i] == arr[j]会发生类型转换,所以以下都为true

    • 1 == true
    • false== []
    • undefined == null
    • false == 0

    要解决以上问题我们可以使用Object.is(arr[i], arr[j])的方法替换arr[i]==arr[j]既可以去除NaN还可以防止发生类型转换。代码这里接不贴出了,大家可以自己写一下运行一下。

    注:为了方便以下arr都使用该处的arr值

    二、利用indexOf()

    使用indexOf(),可以判断一个数组中是否包含某个值,如果存在则返回该元素在数组中的位置,如果不存在则返回-1

    1. functon unique(arr) {
    2. let res =[]
    3. for (let i = 0; i < arr.length; i++) {
    4. if (res.indexOf(arr[i]) === -1) {
    5. res.push(arr[i])
    6. }
    7. }
    8. return res
    9. }
    10. console.log(unique(arr)) //[ 1, 'true', 'a', true, false, undefined, null, NaN, NaN, 'NaN', 0, {}, {}, [], []]
    11. 复制代码

    这里我们新建一个数组来保存去重后的数组,如果该数组不包含元素就将该元素push到该数组中,可以发现这种方法任然没有去掉NaN、{}、[]

    三、利用includes()

    使用includes()方法也可以判断数组是否包含某个特定的元素,如果包含就返回true不包含就返回false。这和indexOf()方法有些类似,所以我们使用includes()进行数组去重和indexOf()的方法原理是一样的。

    1. functon unique(arr) {
    2. letres = []
    3. for (let i = 0; i < arr.length; i++) {
    4. if (!res.includes(arr[i])) {
    5. res.push(arr[i])
    6. }
    7. }
    8. return res
    9. }
    10. 复制代码

    四、利用filter()

    filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。并且filter()不会改变数组,也不会对空数组进行检测filter()方法接收一个回调函数。

    语法:

    1. array.filter(function(item,index,arr), thisValue)
    2. 复制代码
    参数描述
    item必须。当前元素的值
    index可选。当前元素的索引值
    arr可选。当前元素属于的数组对象

    代码实现

    1. function unique(arr) {
    2. return arr.filter((item,index, arr) => {
    3. return arr.indexOf(item) === index
    4. })
    5. }
    6. console.log(unique(arr)) //[ 1, 'true', 'a', true, false, undefined, null, 'NaN', 0, {}, {}, [], [] ]
    7. 复制代码

    这里我们用判断indexOf(item)判断当前元素的索引是否等于当前index,如果相等就返回该元素。

    五、使用对象的特点

    对象是一种以键值对存储信息的结构,并且不能有重复的键。

    1. function unique(arr) {
    2. let obj = {}
    3. for (leti = 0; i < arr.length; i++) {
    4. if (arr[i] in obj) {
    5. obj[arr[i]] ++
    6. } else {
    7. obj[arr[i]] = 10
    8. }
    9. }
    10. return Object.keys(obj) // 以数组的形式返回键
    11. }
    12. console.log(unique(arr)) // [ '0', '1', 'true', 'a', 'false', 'undefined', 'null', 'NaN', '[object Object]', '']
    13. 复制代码

    这种方法的写出来有点问题,因为是用Object.keys(obj)来返回键的集合所以得到的都是字符串的形式。

    六、使用set

    ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。

    1. function unique(arr) {
    2. return [...new Set(arr)]
    3. }
    4. console.log(unique(arr)) //[ 1, 'true', 'a', true, false, undefined, null, NaN, 'NaN', 0, {}, {}, [], [] ]
    5. 复制代码

    这是ES6最常用的方法,得到的效果也还不错。

    七、reduce大法

    1. function unique(arr) {
    2. return arr.reduce((pre, cur) => {
    3. !pre.includes(cur) && pre.push(cur)
    4. return pre
    5. }, [])
    6. }
    7. 复制代码

    来源:https://juejin.cn/post/6844903790257111054
  • 相关阅读:
    使用 MoveIt 控制自己的真实机械臂【4】——了解 MoveIt 的轨迹规划实现机制
    小分子PEG CAS:1352814-07-3生物素-PEG6-丙酸叔丁酯
    SpringMVC
    月子会所管理系统| 月子会所小程序| 数字化门店转型
    4K高清视频素材,拿去不谢。
    如何下载MyBatis呢?
    极速视觉:揭秘YOLO如何革新目标检测速度
    Leetcode-2311. 小于等于 K 的最长二进制子序列
    最新最全计算机专业毕业设计选题精华汇总-持续更新中
    【代码随想录】刷题Day39
  • 原文地址:https://blog.csdn.net/china_coding/article/details/126516451