溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法

發(fā)布時間:2021-04-21 10:51:36 來源:億速云 閱讀:269 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

js的作用是什么

1、能夠嵌入動態(tài)文本于HTML頁面。2、對瀏覽器事件做出響應(yīng)。3、讀寫HTML元素。4、在數(shù)據(jù)被提交到服務(wù)器之前驗(yàn)證數(shù)據(jù)。5、檢測訪客的瀏覽器信息。6、控制cookies,包括創(chuàng)建和修改等。7、基于Node.js技術(shù)進(jìn)行服務(wù)器端編程。

在JS中經(jīng)常會遇到去除數(shù)組中重復(fù)數(shù)據(jù)的需求,在此介紹四種算法以實(shí)現(xiàn)JS數(shù)組去重的功能.

1. 速度最快算法:對象鍵值對法

實(shí)現(xiàn)思路:新建一js對象以及新數(shù)組,遍歷傳入數(shù)組時,判斷值是否為js對象的鍵,不是的話給對象新增該鍵并放入新數(shù)組。

//注意點(diǎn): 判斷 是否為js對象鍵時,會自動對傳入的鍵執(zhí)行“toString()”,不同的鍵可能會被誤認(rèn)為一樣;例如: a[1]、a["1"] 。解決上述問題還是得調(diào)用“indexOf”。
//速度最快, 占空間最多(空間換時間)
function unique(array){
  var n = {}, r = [], len = array.length, val, type;
  for (var i = 0; i < array.length; i++) {
    val = array[i];
    type = typeof val;
    if (!n[val]) {
      n[val] = [type];
      r.push(val);
    } else if (n[val].indexOf(type) < 0) {
      n[val].push(type);
      r.push(val);
    }
  }
  return r;
}
//測試代碼:
var arr=[1,2,3,4,5,29,5,3,1,2];
var rel=unique(arr);
console.log(rel);

運(yùn)行結(jié)果:

JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法

2.最巧妙算法:優(yōu)化遍歷數(shù)組法

實(shí)現(xiàn)思路:獲取沒重復(fù)的最右一值放入新數(shù)組。(檢測到有重復(fù)值時終止當(dāng)前循環(huán)同時進(jìn)入頂層循環(huán)的下一輪判斷)

function unique1(array){
  var r = [];
  for(var i = 0, l = array.length; i<l; i++){
    for(var j = i + 1; j < l; j++)
      if(array[i] == array[j]) j == ++i;
    r.push(array[i]);
  }
  return r;
}
//測試代碼:
var arr=[1,2,3,4,5,29,5,2];
var rel=unique1(arr);
console.log(rel);

運(yùn)行結(jié)果:

JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法

3.算法:排序后相鄰去除法

實(shí)現(xiàn)思路:給傳入數(shù)組排序,排序后相同值相鄰,然后遍歷時新數(shù)組只加入不與前一值重復(fù)的值。

//將相同的值相鄰,然后遍歷去除重復(fù)值
function unique2(array){
  array.sort();
  var re=[array[0]];
  for(var i = 1; i < array.length; i++){
    if( array[i] !== re[re.length-1])
    {
      re.push(array[i]);
    }
  }
  return re;
}
//測試代碼:
var arr=[1,2,3,4,5,29,5,2,3,1];
var rel=unique2(arr);
console.log(rel);

運(yùn)行結(jié)果:

JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法

4.算法:數(shù)組下標(biāo)判斷法

實(shí)現(xiàn)思路:如果當(dāng)前數(shù)組的第i項(xiàng)在當(dāng)前數(shù)組中第一次出現(xiàn)的位置不是i,那么表示第i項(xiàng)是重復(fù)的,忽略掉。否則存入結(jié)果數(shù)組

function unique3(array){
  var n = [array[0]]; //結(jié)果數(shù)組
  //從第二項(xiàng)開始遍歷
  for(var i = 1; i < array.length; i++) {
    //如果當(dāng)前數(shù)組的第i項(xiàng)在當(dāng)前數(shù)組中第一次出現(xiàn)的位置不是i,
    //那么表示第i項(xiàng)是重復(fù)的,忽略掉。否則存入結(jié)果數(shù)組
    if (array.indexOf(array[i]) == i) n.push(array[i]);
  }
  return n;
}
//測試代碼:
var arr=[1,2,3,4,5,29,3,4,2,5,1];
var rel=unique3(arr);
console.log(rel);

運(yùn)行結(jié)果:

JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI