国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript數(shù)組去重由慢到快由繁到簡(優(yōu)化篇)

2019-11-20 09:09:05
字體:
供稿:網(wǎng)友

在進(jìn)行數(shù)組操作時往往會遇到去掉重復(fù)項(xiàng)的問題,下面簡單介紹下數(shù)組去重的方法。

indexOf去重

Array.prototype.unique1 = function() {var arr = [];for (var i = 0; i < this.length; i++) {var item = this[i];if (arr.indexOf(item) === -1) {arr.push(item);}}return arr;}[1,2,3,'4',3,4,3,1,'34',2].unique1(); //[1, 2, 3, "4", 4, "34"]

不過,在 IE6-8 下,數(shù)組的 indexOf 方法還不存在(雖然這已經(jīng)算有點(diǎn)古老的話題了O(∩_∩)O~),但是,程序員就要寫一個indexOf方法:

var indexOf = [].indexOf ? function(arr, item) {return arr.indexOf(item);} :function indexOf(arr, item) {for (var i = 0; i < arr.length; i++) {if (arr[i] === item) {return i;}}return -1;}Array.prototype.unique2 = function() {var arr = [];for (var i = 0; i < this.length; i++) {var item = this[i];if (arr.indexOf(item) === -1) {arr.push(item);}}return arr;}[1,2,3,'4',3,4,3,1,'34',2].unique2(); //[1, 2, 3, "4", 4, "34"]

indexOf還可以以這樣的去重思路:

Array.prototype.unique3 = function(){var arr = [this[0]]; for(var i = 1; i < this.length; i++) {if (this.indexOf(this[i]) == i){arr.push(this[i]);} }return arr;}[1,2,3,'4',3,4,3,1,'34',2].unique3(); //[1, 2, 3, "4", 4, "34"]

hash去重

以上indexOf正確性沒問題,但性能上,兩重循環(huán)會降低性能。那我們就用hash。

Array.prototype.unique4 = function() {var arr = [];var hash = {};for (var i = 0; i < this.length; i++) {var item = this[i];var key = typeof(item) + itemif (hash[key] !== 1) {arr.push(item);hash[key] = 1;}} return arr;}[1,2,3,'4',3,4,3,1,'34',2].unique4(); //[1, 2, 3, "4", 4, "34"]

核心是構(gòu)建了一個 hash 對象來替代 indexOf。空間換時間。注意在 JavaScript 里,對象的鍵值只能是字符串(當(dāng)然,ES6提供了Map數(shù)據(jù)結(jié)構(gòu)。它類似于對象,也是鍵值對的集合,但是“鍵”的范圍不限于字符串,各種類型的值(包括對象)都可以當(dāng)作鍵。也就是說,Object結(jié)構(gòu)提供了“字符串―值”的對應(yīng),Map結(jié)構(gòu)提供了“值―值”的對應(yīng),是一種更完善的Hash結(jié)構(gòu)現(xiàn)。),因此需要var key = typeof(item) + item 來區(qū)分?jǐn)?shù)值 1 和字符串 '1' 等情況。

那如果你想要'4' 和 4 被認(rèn)為是相同的話(其他方法同理)

Array.prototype.unique5 = function(){var arr=[];var hash={};for(var i=0,len=this.length;i<len;i++){if(!hash[this[i]]){ arr.push(this[i]);hash[this[i]]=true;}}return arr;}[1,2,3,'4',3,4,3,1,'34',2].unique5(); //[1, 2, 3, "4", "34"]

排序后去重

Array.prototype.unique6 = function(){this.sort();var arr = [this[0]];for(var i = 1; i < this.length; i++){if( this[i] !== arr[arr.length-1]){arr.push(this[i]);}}return arr;}[1,2,3,'4',3,4,3,1,'34',2].unique6(); //[1, 2, 3, "34", "4", 4]

先把數(shù)組排序,然后比較相鄰的兩個值,排序的時候用的JS原生的sort方法,所以非常快。而這個方法的缺陷只有一點(diǎn),比較字符時按照字符編碼的順序進(jìn)行排序。所以會看到10排在2前面這種情況。不過在去重中不影響。不過,解決sort的這個問題,是sort方法接受一個參數(shù),這個參數(shù)是一個方法:

function compare(value1,value2) {if (value1 < value2) {return -1;} else if (value1 > value2) {return 1;} else {return 0;}}[1,2,5,2,10,3,20].sort(compare); //[1, 2, 2, 3, 5, 10, 20]

Set去重

ES6提供了新的數(shù)據(jù)結(jié)構(gòu)Set。它類似于數(shù)組,但是成員的值都是唯一的,沒有重復(fù)的值。現(xiàn)在瀏覽器正在全面支持,服務(wù)端的node也已經(jīng)支持。

Array.prototype.unique7 = function(){return Array.from(new Set(this));}[1,2,3,'4',3,4,3,1,'34',2].unique7(); //[1, 2, 3, "4", 4, "34"]

方法庫

推薦一個方法庫Underscore.js,在node或?yàn)g覽器js中都很受歡迎。

const _ = require('underscore');_.uniq([1, 2, 1, 3, 1, 4]); //[1, 2, 3, 4]

測試時間

以上方法均可以用一個簡單的方法去測試一下所耗費(fèi)的時間,然后對各個方法做比較擇優(yōu):

console.time("test");[1,2,3,'4',3,4,3,1,'34',2].unique7();console.timeEnd("test");==> VM314:3 test: 0.378ms

讓數(shù)據(jù)變得大一點(diǎn),就隨機(jī)創(chuàng)建100萬個數(shù):

var arr = [];var num = 0;for(var i = 0; i < 1000000; i++){num = Math.floor(Math.random()*100);arr.push(num);}console.time("test");arr.unique7();console.timeEnd("test");

以上所述是小編給大家介紹的JavaScript數(shù)組去重由慢到快由繁到簡,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 黎川县| 台中县| 京山县| 淅川县| 高雄市| 黄大仙区| 社会| 敖汉旗| 广元市| 台州市| 山阳县| 龙井市| 华阴市| 阳泉市| 庆安县| 襄城县| 黄梅县| 玛多县| 石泉县| 阿克| 丰都县| 清新县| 沁阳市| 绥宁县| 乌兰浩特市| 玛多县| 定陶县| 白沙| 青田县| 随州市| 宁夏| 邯郸县| 宜城市| 宁蒗| 西城区| 鹰潭市| 梅州市| 四平市| 内丘县| 渑池县| 文山县|