您好,登錄后才能下訂單哦!
這篇文章主要介紹了JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
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é)果:
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é)果:
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é)果:
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é)果:
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“JS如何實(shí)現(xiàn)的數(shù)組去除重復(fù)數(shù)據(jù)算法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
免責(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)容。