精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何使用JavaScript Set集合更快地編寫代碼

開發 前端
在本文中,我們將討論JavaScript的 Set集合如何使你的代碼更快,尤其是在擴展時。

我敢肯定,有很多開發人員堅持使用基本的全局對象:number,string,object,array和boolean值。

對于許多用例,這些都是你所需要的。但是,如果你想使代碼盡可能快和可擴展,那么這些基本類型并不總是足夠好。

在本文中,我們將討論JavaScript的 Set集合如何使你的代碼更快,尤其是在擴展時。數組可以執行的操作與Set可以執行的操作之間存在大量的交叉。使用Set往往會帶來數組無法實現的運行時優勢。在這篇文章中,我們將探討如何做到這一點。

[[330140]]

Set有何不同?

最根本的區別是數組是索引集合,這意味著數組中的數據值由索引排序。

  1. const arr = [A, B, C, D]; 
  2. console.log(arr.indexOf(A)); // Result: 0 
  3. console.log(arr.indexOf(C)); // Result: 2 

相比之下,Set是一個鍵控集合。 Set使用鍵對數據進行排序,而不是使用索引。Set的元素可以按插入順序進行迭代,并且不能包含任何重復數據。換句話說,集合中的每個項目都必須是唯一的。

主要好處是什么?

直接比較,Set集合比數組具有多個優點,特別是在運行時間上更快:

  • 搜索項目:使用 indexOf() 或 includes() 檢查數組中是否存在某項比較慢。
  • 刪除項目:在Set集合中,可以按項目的值刪除項目。在數組中,等效項是根據元素的索引使用 splice()。與上一點一樣,依賴索引的速度很慢。
  • 插入項目:與使用 push(),unshift() 或等效方法將項目添加到數組相比,將項目添加到Set更快。
  • 儲存NaN:你不能使用 indexOf() 或 include() 來查找值 NaN,而Set可以存儲該值。
  • 刪除重復項:Set對象僅存儲唯一值。如果要避免存儲重復項,則這是優于數組的顯著優勢,在數組中,需要附加代碼來處理重復項。

時間的復雜度是多少?

數組用于搜索項目的方法的線性時間復雜度為O(N)。換句話說,運行時間以與數據大小增加相同的速率增加。

相比之下,Set用于搜索,刪除和插入項目的方法的時間復雜度僅為O(1)——這意味著數據的大小實際上與這些方法的運行時間無關!

Set集合的速度究竟快多少?

盡管運行時間可能會因所使用的系統,所提供數據的大小和其他變量而有很大不同,但我希望我的測試結果能使你對Set的運行速度有實際的了解。我將分享我做的三個簡單測試和獲得的結果。

1. 準備測試

在運行任何測試之前,讓我們創建一個數組和一個Set,每個數組具有一百萬個條目。為簡單起見,我將從0開始,一直到999,999。

  1. let arr = [], set = new Set(), n = 1000000
  2. for (let i = 0; i < n; i++) { 
  3.   arr.push(i); 
  4.   set.add(i); 

2. 測試一:搜索項目

首先,讓我們搜索數字 123123,我們知道它將返回true。

  1. let result; 
  2. console.time('Array');  
  3. result = arr.indexOf(123123) !== -1;  
  4. console.timeEnd('Array'); 
  5. console.time('Set');  
  6. result = set.has(123123);  
  7. console.timeEnd('Set'); 

結果:Array: 0.173ms,set: 0.023ms,set的速度快了7.54倍。

3. 測試二:添加項目

現在,讓我們向每個集合中添加一個新項目。

  1. console.time('Array');  
  2. arr.push(n); 
  3. console.timeEnd('Array'); 
  4. console.time('Set');  
  5. set.add(n); 
  6. console.timeEnd('Set'); 

結果:Array: 0.018ms,set: 0.003ms,set速度提高了6.73倍。

4. 測試三:刪除項目 

最后,讓我們從每個集合中刪除一個項目(我們可以使用剛剛添加的項目)。沒有內置的數組方法,因此我們將創建一個輔助函數以保持所有內容的整潔:

  1. const deleteFromArr = (arr, item) => { 
  2.   let index = arr.indexOf(item); 
  3.   return index !== -1 && arr.splice(index, 1); 
  4. }; 

這是測試的代碼:

  1. console.time('Array');  
  2. deleteFromArr(arr, n); 
  3. console.timeEnd('Array'); 
  4. console.time('Set');  
  5. set.delete(n); 
  6. console.timeEnd('Set'); 

結果:Array: 1.122ms,set: 0.015ms,在這個例子中,Set的速度是驚人的74.13倍!

總的來說,我們可以看到,使用Set而不是數組可以極大地改善運行時。現在讓我們來看看一些實際的例子,在這些例子中,Set集合是有用的。

案例1:從數組中刪除重復的值

如果要快速從數組中刪除重復的值,可以將其轉換為Set。到目前為止,這是過濾唯一值的最簡潔的方法:

  1. const duplicateCollection = ['A', 'B', 'B', 'C', 'D', 'B', 'C']; 
  2. // 如果要將數組變成Set集合 
  3. let uniqueCollection = new Set(duplicateCollection); 
  4. console.log(uniqueCollection) // Result: Set(4) {"A", "B", "C", "D"} 
  5. // 如果你想將值保留在數組中 
  6. let uniqueCollection = [...new Set(duplicateCollection)]; 
  7. console.log(uniqueCollection) // Result: ["A", "B", "C", "D"] 

案例2:一個Google面試問題

給定一個無序的整數數組和一個值 sum,如果可以相加任何兩個項目以使它們等于 sum 的值,則返回 true。否則,返回false。

因此,如果給定數組 [3,5,1,4] 和值 9,則我們的函數應返回 true,因為 4 + 5 = 9。

解決這個問題的一種很好的方法是遍歷數組,同時創建一組Set。

讓我們將這種想法應用于上面的示例。當我們遇到 3 時,可以將 6 加到我們的Set中,因為我們知道我們需要找到一個 9 的和。然后,每次我們接觸數組中的新值時,我們都可以檢查它是否在我們的Set中。當我們到了 5 ,我們就會把 4 加入到我們的Set中。然后,當我們最終遇到 4 時,我們也會在我們的Set中找到它,所以我們可以返回 true。

該解決方案可能如下所示:

  1. const findSum = (arr, val) => { 
  2.   let searchValues = new Set(); 
  3.   searchValues.add(val - arr[0]); 
  4.   for (let i = 1length = arr.length; i < length; i++) { 
  5.     let searchVal = val - arr[i]; 
  6.     if (searchValues.has(arr[i])) { 
  7.       return true; 
  8.     } else { 
  9.       searchValues.add(searchVal); 
  10.     } 
  11.   }; 
  12.   return false; 
  13. }; 

這是一個更簡潔的版本:

  1. const findSum = (arr, sum) => 
  2.   arr.some((set => n => set.has(n) || !set.add(sum - n))(new Set)); 

因為Set.prototype.has() 的時間復雜度僅為O(1),所以使用Set來存儲而不是數組可以幫助我們整體解決方案獲得線性運行時間O(N)。

如果我們改為依賴 Array.prototype.indexOf() 或 Array.prototype.includes() ,它們的時間復雜度均為O(N),則總運行時間將為O(N²),慢得多!

如果你以前從未接觸過JavaScript Set,希望我已經展示了它們的實用性!

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2021-02-03 21:24:42

Joplin筆記

2021-03-25 12:50:31

Linux磁盤命令

2012-07-04 15:05:14

ibmdw

2021-08-31 09:12:18

StringIntLong

2021-10-04 09:25:28

Flutter圖像Web

2022-06-07 09:30:35

JavaScript變量名參數

2014-04-21 10:14:52

PromisesJavaScript

2013-09-25 10:18:26

Java啟發式搜索

2013-04-15 09:02:43

JavaScriptJS

2010-02-02 13:59:11

Python編寫

2011-03-04 10:11:09

JavascriptAPI

2022-06-10 10:01:17

MacDockerLinux

2010-02-03 09:27:21

編寫Python程序

2023-10-10 08:00:00

2019-05-16 14:50:32

CythonPython編程語言

2022-06-21 09:26:21

Shell腳本JavaScript

2016-11-30 18:35:03

JavaScript

2012-12-17 13:51:22

Web前端JavaScriptJS

2025-03-07 11:06:06

大型語言模型AICoD

2012-03-15 11:21:19

Java
點贊
收藏

51CTO技術棧公眾號

久久奇米777| 中文字幕免费一区二区| 欧美性xxxxxxx| 亚洲欧美国产精品桃花| 精品人妻aV中文字幕乱码色欲 | 一区精品在线| 亚洲AV午夜精品| 视频在线观看一区| 欧美床上激情在线观看| 魔女鞋交玉足榨精调教| 国产一区二区三区亚洲综合| 黄色成人在线免费| 三级网在线观看| 强乱中文字幕av一区乱码| 电影一区二区三区| 成人欧美一区二区三区黑人麻豆| 国产v亚洲v天堂无码| 国产亚洲欧美日韩高清| 欧美福利影院| 一区二区三区视频观看| 黑森林av导航| 亚洲三级电影| 日本乱码高清不卡字幕| 日本男女交配视频| 日本中文字幕在线播放| 91影院在线免费观看| 91在线免费网站| 亚洲国产成人精品女人久久| 国产精品豆花视频| 久久久91精品国产| 亚洲av成人无码久久精品| 999精品视频在这里| 欧美日韩在线播放三区四区| 免费无遮挡无码永久视频| h网站久久久| 国产精品青草综合久久久久99| 精品综合久久| 人妻无码一区二区三区久久99 | 91精品国产色综合久久不卡98口| 久久精品国产亚洲AV成人婷婷| 羞羞色国产精品网站| 精品免费一区二区三区| 中文字幕第22页| 精品亚洲a∨| 91国产成人在线| 欧美性大战久久久久xxx| 狂野欧美激情性xxxx欧美| 综合亚洲深深色噜噜狠狠网站| 日韩欧美三级电影| 国内三级在线观看| 久久蜜臀精品av| 欧美日韩亚洲免费| 精品福利视频导航大全| 久久精品一区二区| 日产精品久久久一区二区| 可以在线观看的av| 国产日产欧美一区二区视频| 欧美一进一出视频| 国产精品毛片一区二区三区四区| 国产亚洲综合性久久久影院| 蜜桃精品久久久久久久免费影院| 性猛交xxxx| 久久久美女毛片| 天堂av一区二区| 免费av网站在线观看| 亚洲视频一二区| 久久久天堂国产精品| 色呦呦在线资源| 污片在线观看一区二区| 日本三级免费观看| 777午夜精品电影免费看| 欧美日本一区二区三区| 两性午夜免费视频| 成午夜精品一区二区三区软件| 亚洲成av人乱码色午夜| 91av在线免费| 欧美日韩一二三四| 另类专区欧美制服同性| 国产无遮挡又黄又爽在线观看| 亚洲美女色禁图| 国产精品扒开腿做| av网站免费大全| 成人动漫在线一区| 日本高清不卡一区二区三| 91精彩在线视频| 亚洲精选一二三| 午夜精品久久久久久久无码 | 91精品国产综合久久香蕉最新版| 国产高清视频免费观看| 99久久精品99国产精品| 神马影院我不卡午夜| caopo在线| 日韩欧美高清视频| 色婷婷激情视频| 神马日本精品| 久久亚洲国产精品成人av秋霞| 人人干人人干人人干| 免费美女久久99| 国产日韩欧美综合精品| 99视频在线观看地址| 亚洲不卡一区二区三区| 一道本视频在线观看| 国产综合精品久久久久成人av| 日韩一区二区三区精品| 亚洲人成人99网站| 麻豆changesxxx国产| 老司机久久99久久精品播放免费| 亚洲自拍偷拍色图| 青青久在线视频免费观看| 亚洲免费大片在线观看| 免费观看成人在线视频| 成人福利一区| 精品国产一区二区三区久久| 亚洲另类欧美日韩| 国产精品一品视频| 一区二区高清视频| 成人性教育av免费网址| 日韩欧美成人午夜| 99久久久免费精品| 日韩极品在线观看| 久久久久一区二区| 高h视频在线播放| 欧美一区二区三区视频在线观看| 久久精品—区二区三区舞蹈| 9国产精品视频| 成人看片视频| 大地资源网3页在线观看| 在线免费观看一区| 国内精品久久99人妻无码| 黑丝一区二区| 不卡日韩av| 在线免费观看的av| 日韩一区二区三区四区五区六区| 337人体粉嫩噜噜噜| 午夜一级在线看亚洲| 国产伦精品一区二区三区照片 | 日韩av三级在线观看| 日本精品久久久久| 亚洲线精品一区二区三区八戒| 中文字幕第一页在线视频| 日韩国产一区| 国产免费一区二区三区香蕉精| 国产精品无码2021在线观看| 日本高清不卡aⅴ免费网站| 捆绑凌虐一区二区三区| 狠狠88综合久久久久综合网| 成人自拍爱视频| 美女航空一级毛片在线播放| 欧美成人vr18sexvr| 美女毛片在线观看| 成人夜色视频网站在线观看| 一二三在线视频| 91综合久久爱com| 97国产在线视频| 午夜在线视频观看| 日韩欧美精品中文字幕| 日本性高潮视频| 久久69国产一区二区蜜臀| 亚洲激情一区二区三区| 欧洲亚洲精品久久久久| www.xxxx精品| www.com在线观看| 亚洲大片一区二区三区| 国产激情在线免费观看| 日韩精品一二区| 中文字幕在线亚洲精品| 日韩在线精品强乱中文字幕| 久久久在线免费观看| 青春有你2免费观看完整版在线播放高清 | 午夜伦理福利在线| 一区二区三欧美| 国产熟女精品视频| 亚洲成av人**亚洲成av**| 国产男男chinese网站| 久久久夜精品| 综合视频免费看| 久久97久久97精品免视看秋霞| 欧美伊久线香蕉线新在线| av中文天堂在线| 日韩一区二区三区四区| 久久久久久久黄色片| 国产调教视频一区| 中文字幕无码毛片免费看| 一本一本久久| 亚洲国产精品www| 亚洲啊v在线免费视频| 日本精品一区二区三区在线播放视频| av黄色在线观看| 日韩精品一区二区三区老鸭窝| 国产精品一区二区三区四| 中文字幕在线一区| 性欧美丰满熟妇xxxx性久久久| 青青草原综合久久大伊人精品优势| 在线观看一区二区三区三州| 日韩极品在线| 97se视频在线观看| av在线一区不卡| 欧美国产极速在线| 成年人在线观看视频| 精品国产一区二区三区四区四| 不卡av电影在线| 亚洲综合激情网| 蜜桃av免费在线观看| 成人av资源在线观看| 97超碰人人爽| 校园激情久久| 超级碰在线观看| 国产一区二区区别| 国产欧美日韩在线播放| 91精品国产色综合久久不卡粉嫩| 欧美在线www| 欧美wwww| 久久夜色精品国产| aaa在线观看| 综合网在线视频| 五月综合激情| 久久久久久国产精品mv| 久久av偷拍| 国产精品入口日韩视频大尺度| 91福利在线尤物| 欧美成年人视频网站| 91在线视频| 国产亚洲精品久久久久久| 乱色精品无码一区二区国产盗| 欧美日韩精品一区二区| www.国产毛片| 欧美性20hd另类| 国产成人一区二区三区影院在线 | 亚洲国内精品视频| 91亚洲国产成人精品一区| 在线视频观看一区| 亚洲GV成人无码久久精品| 精品欧美激情精品一区| 久久久久免费看| 一个色综合av| 青青草原免费观看| 亚洲蜜臀av乱码久久精品| frxxee中国xxx麻豆hd| 国产精品免费视频网站| 毛片aaaaaa| 中文字幕亚洲精品在线观看| 美国美女黄色片| 国产精品美女久久久久久| 谁有免费的黄色网址| 久久久久久久久免费| 白白色免费视频| 欧美精彩视频一区二区三区| 中文字幕在线看高清电影| 久久这里只有精品6| japanese中文字幕| 国产色爱av资源综合区| 在线观看亚洲大片短视频| 国产精品久久久久久久久免费桃花| 91视频免费看片| 亚洲日本在线看| 免费一级黄色大片| 亚洲成av人在线观看| 国产一级18片视频| 色婷婷av一区| 中文字幕自拍偷拍| 91精品国产综合久久精品图片| 性做久久久久久久久久| 亚洲第一色中文字幕| 亚洲三级中文字幕| 一区二区国产精品视频| 日本中文字幕视频在线| 九九精品视频在线| 国产理论在线| 国产精品毛片a∨一区二区三区|国| 成人在线免费av| 91亚洲精品丁香在线观看| 日本国产精品| 亚洲春色在线| 国产精品国码视频| 欧美精品第三页| 国产精品一区三区| 91精品国产自产| 国产精品成人免费在线| 国产午夜精品无码一区二区| 色噜噜狠狠成人网p站| 亚洲一区 中文字幕| 日韩欧美国产高清| 国产在线黄色| 欧美日韩高清在线观看| 香蕉视频亚洲一级| 亚洲www视频| 亚洲欧洲色图| 日韩中文字幕在线不卡| 麻豆亚洲精品| 夜夜爽久久精品91| 久久免费精品国产久精品久久久久| 黄色片网站在线播放| 午夜久久久影院| 国产精品高潮呻吟久久久| 亚洲精品xxx| 欧美午夜电影一区二区三区| 78色国产精品| 国产精品高清一区二区| 欧洲亚洲一区二区| 黑人一区二区| 色婷婷一区二区三区在线观看| 99久久精品费精品国产一区二区| 亚洲 欧美 变态 另类 综合| 欧美日韩国产一中文字不卡| 国产伦精品一区二区三区免.费| 亚洲精品www久久久| a级毛片免费观看在线| 国产精品高清网站| 日韩欧美影院| 日韩欧美猛交xxxxx无码| 蜜桃av一区二区在线观看| 噜噜噜在线视频| 一区二区久久久久久| 亚洲一区二区激情| 亚洲图片在线综合| 免费成人在线电影| 国产精品视频免费一区二区三区| 久久综合88| 日本a√在线观看| 久久综合色婷婷| 欧美三级一区二区三区| 欧美成人免费网站| av免费在线免费| 91精品久久久久久久久久另类 | 成人免费观看cn| 国产精品18久久久久久vr| 日本不卡一区视频| 欧洲一区在线电影| 黄色电影免费在线看| 国产91|九色| 视频福利一区| 欧美色图色综合| 91视视频在线观看入口直接观看www | 久久久精品日韩| 好吊一区二区三区视频| 亚洲第一福利视频在线| 乱精品一区字幕二区| 久久久亚洲影院你懂的| 亚洲成人五区| 妞干网视频在线观看| 国产精品一区二区在线播放| 欧美成人精品激情在线视频| 7777女厕盗摄久久久| 国产精品剧情一区二区在线观看 | 国产日产亚洲系列最新| www.亚洲人.com| 97色婷婷成人综合在线观看| 青青草原国产免费| 精品一区在线看| 91成人福利视频| 欧美哺乳videos| 1024在线看片你懂得| 久久久婷婷一区二区三区不卡| 老鸭窝毛片一区二区三区 | 欧美在线观看视频一区| 中日韩av在线播放| 最新中文字幕一区二区三区| 国产av精国产传媒| 久久久久久久久久婷婷| 麻豆一区一区三区四区| 国产特级黄色大片| 国产视频一区二区三区在线观看| 伊人成年综合网| 日韩亚洲一区二区| 亚洲一区二区三区在线免费| 国产美女主播在线| 2021国产精品久久精品| 国产乡下妇女三片| 久久精品久久久久| 国产精品一区二区三区美女| 亚洲熟女乱色一区二区三区| 国产欧美视频在线观看| 国产三级视频在线播放| 欧美—级a级欧美特级ar全黄| 欧美综合精品| 亚洲一级免费观看| 一区二区三区欧美日| 午夜国产在线观看| 国产精品专区h在线观看| 影音先锋日韩在线| 一女三黑人理论片在线| 欧美日韩一区二区欧美激情 | 国产脚交av在线一区二区| 欧美韩日高清| a视频免费观看| 欧美人成免费网站| 亚洲成人日韩在线| 亚洲女女做受ⅹxx高潮| 天天干天天草天天射| 国产精品亚洲片夜色在线| 国产一区亚洲| xxxxx99| 亚洲福利视频免费观看| 北条麻妃亚洲一区| 亚洲美女屁股眼交| 内衣办公室在线| 91免费观看| 日韩中文字幕区一区有砖一区| 欧美精品成人久久| 中文字幕国产亚洲|