欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

数组去重方法

程序员文章站 2022-07-10 11:50:20
方法一: ES6 数据去重法 function noRepeat(arr) { return Array.from(new Set(arr)); } console.log(noRepeat([1,1,1,2,3,4])); // [1,2,3,4] 方法二: 创建新数组,判断新数组中是否有重复的元 ......
方法一: es6 数据去重法
function norepeat(arr) {
  return array.from(new set(arr));
}
console.log(norepeat([1,1,1,2,3,4])); // [1,2,3,4]
方法二: 创建新数组,判断新数组中是否有重复的元素
function norepeat(arr) {
  var newarr = [];
  for(var i in arr) {
  // 遍历出重数组,如果新数组中不存在遍历的元素, 就把该元素加入新数组
     if(newarr.indexof(arr[i]) ===-1){
         newarr.push(arr[i]);
     }
   }
   return newarr;
}
console.log(norepeat([2,2,3,3,4])); // [2,3,4]
方法三:  数组排序后, 相邻的两元素做比较
function norepeat(arr) {
    // 出重数组进行排序
    arr.sort();
    // 取排序后的数组的第一个元素
    var newarr = [arr[0]];
    for(var i in arr) {
    // 遍历出重数组, 遍历的元素与新数组最后一个元素进行比较;如果不同, 则加入新数组
        if(arr[i] !== newarr[newarr.length-1]) {
            newarr.push(arr[i]);
        }
    }
    return newarr;
}
console.log(norepeat([2,2,3,3,4,4,4])); // [2,3,4]
方法四: 利用对象key的唯一性进行去重
function norepeat(arr) {
    var obj = {}, newarr = [];
    for(var i in arr) {
    // 当前遍历元素最为obj的key,若obj.key为undefined,改元素进入新数组
        if(!obj[arr[i]]) {
            obj[arr[i]] = true;
            newarr.push(arr[i]);
        }
    }
    return newarr;
}
console.log(norepeat([1,2,3,4,4,4,4,4])); //[1,2,3,4]        

 

ps:此文为记录个人学习, 若有纰漏,请指出