幾種去除數組中重復元素的方法、數組去重


工作中遇到的一個問題,就是去除數組中重復的元素,記錄一下幾種有效的方法:

第一種思路:遍歷要刪除的數組arr, 把元素分別放入另一個數組tmp中,在判斷該元素在arr中不存在才允許放入tmp中。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>去除數組重復項</title>
</head>
<body>
    <script type="text/javascript"> 
    var color = ['red','blue','green','pink','yellow','blue','black','red'];
    function unique(arr){
        // 遍歷arr,把元素分別放入tmp數組(不存在才放)
        var tmp = new Array();
        for(var i in arr){
            //該元素在tmp內部不存在才允許追加
            if(tmp.indexOf(arr[i])==-1){
                tmp.push(arr[i]);
            }
        }
        return tmp;
    }
    var arr = unique(color);
    console.log(arr);
</script>
</body>
</html>

第二種思路是:把目標數組arr的元素值和鍵的位置調換 自動就把重復的元素給刪除掉了,調換后的樣子:array('red'=>1,'blue'=>1,'green'=>1,'pink'=>1,'yellow'=>1,'black'=>1)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>去除數組重復項</title>
</head>
<body>
    <script type="text/javascript">
        var color = ['red','blue','green','pink','yellow','blue','black','red'];
        function unique(arr){
            var tmp = new Array();
            for(var m in arr){
                tmp[arr[m]]=1;
            }
            //再把鍵和值的位置再次調換
            console.log(tmp);
            var tmparr = new Array();
            for(var n in tmp){
                tmparr.push(n);
            }
            return tmparr;
        }
        var arr = unique(color);
        console.log(arr);
    </script>
</body>
</html>

第三種思路:我們可以 用一個hashtable的結構記錄已有的元素,這樣就可以避免內層循環。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>去除數組重復項</title>
</head>
<body>
    <script type="text/javascript">
          var color = ['red','blue','green','pink','yellow','blue','black','red'];
          function unique(arr) {
            var result = [], hash = {};
            for (var i = 0, elem; (elem = arr[i]) != null; i++) {
                if (!hash[elem]) {
                    result.push(elem);
                    hash[elem] = true;
                }
            }
            return result;
         }
         var arr = unique(color);
         console.log(arr);
    </script>
</body>
</html>

 ----------------------------------------------------------------------------------------------------補充----------------------------------------------------------------------------------------------------

第四種思路:使用ES6數組的reduce方法,封裝了一個函數(推薦)

/**
 * 數組去重
 * @param {*} arr 接收的原數組
 * @param {*} key 如果是對象數組[{id: 1}, {id: 2}, {id: 3}],則需要以什么key作為重復的標准,普通數組[1,2,3,2]不需要
 */
export function arrUnique(arr, key) {
  let returnArr = [];
  if (key) {
    // 對象數組去重
    const obj = {};
    returnArr = arr.reduce((cur, next) => {
      obj[next[key]] ? '' : obj[next[key]] = true && cur.push(next);
      return cur;
    }, []);
    return returnArr;
  }
  // 普通數組去重
  returnArr = arr.reduce((cur, next) => {
    !cur.includes(next) && cur.push(next);
    return cur;
  }, []);
  return returnArr;
}

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM