您好,登錄后才能下訂單哦!
這篇文章主要介紹了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);
運行結果:
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);
運行結果:
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);
運行結果:
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如何實現的數組去除重復數據算法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。