中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

JS如何實現的數組去除重復數據算法

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

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

js的作用是什么

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

在JS中經常會遇到去除數組中重復數據的需求,在此介紹四種算法以實現JS數組去重的功能.

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

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

//注意點: 判斷 是否為js對象鍵時,會自動對傳入的鍵執行“toString()”,不同的鍵可能會被誤認為一樣;例如: a[1]、a["1"] 。解決上述問題還是得調用“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);

運行結果:

JS如何實現的數組去除重復數據算法

2.最巧妙算法:優化遍歷數組法

實現思路:獲取沒重復的最右一值放入新數組。(檢測到有重復值時終止當前循環同時進入頂層循環的下一輪判斷)

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);

運行結果:

JS如何實現的數組去除重復數據算法

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

實現思路:給傳入數組排序,排序后相同值相鄰,然后遍歷時新數組只加入不與前一值重復的值。

//將相同的值相鄰,然后遍歷去除重復值
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);

運行結果:

JS如何實現的數組去除重復數據算法

4.算法:數組下標判斷法

實現思路:如果當前數組的第i項在當前數組中第一次出現的位置不是i,那么表示第i項是重復的,忽略掉。否則存入結果數組

function unique3(array){
  var n = [array[0]]; //結果數組
  //從第二項開始遍歷
  for(var i = 1; i < array.length; i++) {
    //如果當前數組的第i項在當前數組中第一次出現的位置不是i,
    //那么表示第i項是重復的,忽略掉。否則存入結果數組
    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);

運行結果:

JS如何實現的數組去除重復數據算法

感謝你能夠認真閱讀完這篇文章,希望小編分享的“JS如何實現的數組去除重復數據算法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

姚安县| 梁山县| 唐河县| 临高县| 石棉县| 衡南县| 全椒县| 沧州市| 太康县| 苍梧县| 万盛区| 江北区| 班戈县| 阿城市| 资中县| 唐山市| 延边| 潮州市| 斗六市| 连州市| 惠东县| 漳州市| 丘北县| 奉贤区| 武定县| 东乌珠穆沁旗| 新兴县| 宁安市| 阿克苏市| 林甸县| 获嘉县| 台北县| 北京市| 当阳市| 平顺县| 万州区| 长白| 平陆县| 高陵县| 乐亭县| 如东县|