摘要:背景項目需要前端判斷已建列表是否存在重復(fù)的數(shù)據(jù),經(jīng)過校驗后再進行下一步。整體思路是將數(shù)組中的數(shù)據(jù)放入中,然后比較和原數(shù)組的長度,如果不一致,那么說明存在重復(fù)的數(shù)據(jù)。
背景
項目需要前端判斷已建列表是否存在重復(fù)的數(shù)據(jù),經(jīng)過校驗后再進行下一步。以下為逐步改良的過程,雖然整個過程并不復(fù)雜而且沒什么技術(shù)含量,還是記錄一下以便他人。
最單純的方法最單純的方法當然是直接兩層for循環(huán)判斷,但是如果當數(shù)據(jù)量大的時候,計算量也將指數(shù)上漲,所以非常不好,果斷拋棄。
排序后查重這種思路主要是拿到數(shù)據(jù)之后先封裝到數(shù)組中,然后對數(shù)組進行一次排序,然后從頭到尾遍歷看自己的后一個是否相同即可,如果相同,直接返回。這種方法多出了一次對實際業(yè)務(wù)沒有用處的排序操作,也有些缺陷。
利用Set的特性Set的特性是不重復(fù),所以思考可以利用這一點進行比對。整體思路是將數(shù)組中的數(shù)據(jù)放入Set中,然后比較Set和原數(shù)組的長度,如果不一致,那么說明存在重復(fù)的數(shù)據(jù)。
代碼如下:
var sourceArray = [1,2,3,4,5]; var tempSet = new Set(); for(i = 0;i就在我美滋滋的已經(jīng)把算法實現(xiàn)到我們項目的時候,前端的妹子告訴我Set的兼容性存在問題,所以不得不拋棄了這個想法,進入了下一步的優(yōu)化。
位圖的思想這個標題是我根據(jù)位圖排序的思想起的名字,(位圖排序是一種很好玩的排序思路,有興趣可以百度)。這種優(yōu)化的主要思路是設(shè)置了一個標志位的數(shù)組,如果存在則對應(yīng)位置為true。如果某一個數(shù)據(jù)發(fā)現(xiàn)自己的位置已經(jīng)是true了,那么說明存在重復(fù)的數(shù)據(jù)了。
代碼如下:var sourceArray = [1,2,3,4,5,4,5]; var flagArray = new Array(); for(i = 0;i思路的發(fā)展 開始動手的時候已經(jīng)知道兩層循環(huán)是不行的,所以一定不會采取這種方式,然后想到的是是否已經(jīng)存在重復(fù)的輪子,也就是說,有沒有函數(shù)能直接判斷重復(fù),查了一下好像沒有,于是想到了Set這個數(shù)據(jù)結(jié)構(gòu)的特性,往這個上面靠,所以誕生了第三種方案,但是后來又發(fā)現(xiàn)兼容性問題,所以最終采用了第四種方案。
整體的思路就是這樣,或許知道了某一種優(yōu)化可以牢記于心,以后直接用,但是如果掌握了優(yōu)化的思路,就可以面對各種場景思考方案,更活而不是死記。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/84728.html
距離上次發(fā)文,已經(jīng)有一段時間了,最近工作比較忙,這不眼看快雙十一了,就相當于給大家一些福利吧! showImg(https://segmentfault.com/img/remote/1460000016538082?w=250&h=250); 一、什么是數(shù)組去重 簡單說就是把數(shù)組中重復(fù)的項刪除掉,你 GET 到了嗎 ?下面我將簡單介紹下幾種基本的方法及其優(yōu)缺點。 二、方法匯總 兩層循環(huán) 無相同...
摘要:題目已知如下數(shù)組編寫一個程序?qū)?shù)組扁平化去并除其中重復(fù)部分數(shù)據(jù),最終得到一個升序且不重復(fù)的數(shù)組實現(xiàn)數(shù)組扁平化去重排序解析數(shù)組扁平化判斷數(shù)組子元素是否為數(shù)組是的話進行遞歸否則把子元素變?yōu)閿?shù)組的執(zhí)行結(jié)果為的執(zhí)行結(jié)果為數(shù)組去重通過實現(xiàn) 題目: 已知如下數(shù)組:var arr = [ [1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, ...
摘要:的擴展知識對于哈希表來說,最重要的莫過于生成哈希串的哈希算法和處理沖突的策略了。由于鏈表的查找需要遍歷,如果我們將鏈表換成樹或者哈希表結(jié)構(gòu),那么就能大幅提高沖突元素的查找效率。 最近在整理數(shù)據(jù)結(jié)構(gòu)和算法相關(guān)的知識,小茄專門在github上開了個repo https://github.com/qieguo2016...,后續(xù)內(nèi)容也會更新到這里,歡迎圍觀加星星! js對象 js中的對象是基...
摘要:返回一個布爾值,表示該值是否為的成員。清除所有成員,沒有返回值。上面代碼中,方法返回的遍歷器,同時包括鍵名和鍵值,所以每次輸出一個數(shù)組,它的兩個成員完全相等。因此,適合臨時存放一組對象,以及存放跟對象綁定的信息。 Js大部分歷史時期都只存在一種集合類型,也就是數(shù)組類型。數(shù)組在 JS 中的使用正如其他語言的數(shù)組一樣,但缺少更多類型的集合導(dǎo)致數(shù)組也經(jīng)常被當作隊列與棧來使用。數(shù)組只使用了數(shù)值...
閱讀 2498·2021-08-11 11:16
閱讀 2938·2019-08-30 15:55
閱讀 3337·2019-08-30 12:53
閱讀 1578·2019-08-29 13:28
閱讀 3271·2019-08-28 18:17
閱讀 944·2019-08-26 12:19
閱讀 2475·2019-08-23 18:27
閱讀 712·2019-08-23 18:17