精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

一级片在线免费观看视频| 久久亚洲AV无码专区成人国产| 超碰在线观看免费| 成人综合在线视频| 国产999精品| 久久av红桃一区二区禁漫| 一区二区三区四区视频免费观看| 黑人狂躁日本妞一区二区三区 | 国外成人在线直播| 男人舔女人下部高潮全视频| 日韩综合久久| 性做久久久久久| 一区二区精品免费视频| 天天射天天色天天干| 久久精品国产一区二区三| 国内自拍欧美激情| 免费国产羞羞网站美图| 国产精品视频一区二区三区四蜜臂| 欧美精品一卡二卡| 91av在线免费播放| 91制片在线观看| 亚洲欧洲av另类| 青青草原成人| 四虎精品在线| 风间由美性色一区二区三区| 国产精品色悠悠| 日本少妇在线观看| 欧美激情综合色综合啪啪| 在线看日韩av| 免费成人深夜夜行p站| 一区二区三区国产好| 欧美精品粉嫩高潮一区二区| 日本成人在线免费视频| 国产高清中文字幕在线| 一区二区三区四区中文字幕| 一区二区三区久久网| 国产主播福利在线| 久久综合狠狠综合久久综合88| 国产精品theporn88| 99在线小视频| 国产精品亚洲午夜一区二区三区 | 超碰在线人人爱| 成人影院av| 日韩欧中文字幕| 91视频 -- 69xx| 校园春色亚洲| 欧美三级欧美成人高清www| 国产妇女馒头高清泬20p多| 在线视频中文字幕第一页| 1024成人网| 美女在线免费视频| 黄色的网站在线观看| 国产精品免费久久| 欧美日韩视频免费在线观看| 蜜芽在线免费观看| 亚洲欧洲日韩女同| 51xx午夜影福利| 毛片大全在线观看| 亚洲超丰满肉感bbw| 免费拍拍拍网站| 成人免费网站观看| 欧美日韩国产在线播放| 免费高清在线观看免费| 日韩精品99| 在线观看免费成人| 日日干夜夜操s8| 999精品嫩草久久久久久99| 欧美一二区视频| 88av在线播放| 精品香蕉视频| 久久综合亚洲社区| 亚洲国产综合久久| 久久深夜福利| 91在线观看免费| 亚洲精品久久久久久无码色欲四季 | 爱爱的免费视频| 国产一区二区三区四区五区| 最近2019年好看中文字幕视频| 欧美爱爱免费视频| 日韩视频一区| 国产精品美女www爽爽爽视频| 亚洲天堂网在线视频| 国产一区二三区| 国产一区自拍视频| 成人亚洲性情网站www在线观看| 国产精品污网站| 日本免费成人网| 色是在线视频| 欧美精选一区二区| 国产精品久久无码| 欧美oldwomenvideos| 欧美成人免费小视频| 日韩特级黄色片| 美国欧美日韩国产在线播放| 91九色露脸| 男女视频在线观看| 亚洲美女视频在线观看| 国产性xxxx18免费观看视频| 欧美aaaaaaaa| 亚洲激情自拍图| 69夜色精品国产69乱| 国产深夜精品| 亚洲综合在线做性| 国产三级电影在线| 亚洲午夜av在线| 中文字幕成人免费视频| 日韩有码中文字幕在线| 麻豆乱码国产一区二区三区 | 久久亚洲导航| 欧美手机在线视频| 无遮挡aaaaa大片免费看| 欧美激情aⅴ一区二区三区| 国产精品自拍网| 五月天丁香视频| 亚洲精品中文在线影院| 最新天堂在线视频| 综合色就爱涩涩涩综合婷婷| 欧美国产亚洲精品久久久8v| 自拍偷拍色综合| 99国产精品国产精品毛片| 黄黄视频在线观看| 97欧美成人| 亚洲美女在线观看| 日本五十熟hd丰满| 国产suv精品一区二区6| 三年中国中文在线观看免费播放| 激情开心成人网| 日韩精品欧美国产精品忘忧草| 久久久久成人网站| 国产九九视频一区二区三区| 亚洲国产精品一区二区第一页 | 91高清在线观看视频| 欧美三级三级三级| 在线免费看黄视频| 日韩一区二区免费看| 国产精品久久久久久久久久直播| 在线三级中文| 日韩精品专区在线影院观看| 91人妻一区二区三区蜜臀| 乱一区二区av| 在线看视频不卡| 激情中国色综合| 在线观看中文字幕亚洲| 探花国产精品一区二区| 国产欧美日韩另类视频免费观看| 丰满人妻中伦妇伦精品app| 国产精品一线| 欧美一区视频在线| 邻居大乳一区二区三区| 色综合久久久久综合| 久久只有这里有精品| 久久一区精品| 水蜜桃一区二区三区| 国产激情欧美| 久久五月天色综合| 午夜精品久久久久久久96蜜桃 | 日本在线一区二区三区| 欧美寡妇偷汉性猛交| 日本激情一区二区| 偷拍与自拍一区| 97伦伦午夜电影理伦片| 久久综合九色| 一本一道久久a久久精品综合| 午夜不卡一区| 欧美激情xxxxx| 性插视频在线观看| 在线看日韩精品电影| 91香蕉视频污在线观看| 丁香另类激情小说| 狠狠爱免费视频| 久久社区一区| 国产乱码精品一区二区三区中文 | 成人高清视频观看www| 羞羞的视频在线观看| 国产视频在线观看一区二区| 国产一级精品毛片| 玉米视频成人免费看| 少妇一级淫片免费放播放| 久久深夜福利| 91精品国产入口在线| 狠狠久久综合婷婷不卡| 中文不卡1区2区3区| 在线日韩av观看| www.激情五月| 欧美小视频在线| 一级片一级片一级片| 99久久免费精品| 在线观看免费的av| 亚洲深爱激情| 国产av第一区| 亚洲伊人春色| 99视频在线| 欧美日韩尤物久久| 欧美精品第一页在线播放| 国产福利免费在线观看| 日韩免费性生活视频播放| 亚洲熟女综合色一区二区三区| 日韩毛片视频在线看| 91成人在线免费视频| 国产白丝网站精品污在线入口| 成人精品视频一区二区| 欧美日韩综合| 一本久久a久久精品vr综合 | 免费在线观看av网址| 国产欧美一区二区三区鸳鸯浴 | 秋霞网一区二区| 欧美人妖巨大在线| 久久久久久在线观看| 亚洲精品国产精华液| 丁香花五月婷婷| heyzo一本久久综合| 污免费在线观看| 蜜桃av一区二区| 日韩精品视频久久| 99视频一区| 国产夫妻自拍一区| 在线中文字幕第一区| 日韩欧美一区二区三区四区五区| 91成人精品在线| 51蜜桃传媒精品一区二区| 欧美黄页免费| 国产精品入口夜色视频大尺度 | caoporn97在线视频| 中文字幕精品视频| 青青久在线视频| 日韩av网址在线| 高h震动喷水双性1v1| 538在线一区二区精品国产| 最近中文字幕在线观看视频| 欧美日韩国产中文精品字幕自在自线| 欧美黄色免费看| 亚洲另类在线制服丝袜| 亚洲xxxx3d动漫| 亚洲欧洲99久久| 中文字幕观看av| 国产精品久久毛片| 久久精品日韩无码| 国产精品久久久久三级| 久久久久99精品成人| 国产蜜臀av在线一区二区三区| 鲁丝一区二区三区| 国产日韩欧美a| 国产激情av在线| 欧美激情一区二区| 四虎永久免费地址| 18欧美亚洲精品| 亚洲最大的黄色网址| 夜夜精品浪潮av一区二区三区| 性色av无码久久一区二区三区| 亚洲免费av在线| 国产无精乱码一区二区三区| 亚洲一区在线视频| 国产69精品久久久久久久久久| 午夜不卡av免费| 国产无遮挡呻吟娇喘视频| 欧美日韩中文字幕在线视频| av一级在线观看| 欧美系列一区二区| 国产乱叫456在线| 精品日韩一区二区三区免费视频| 亚洲va久久久噜噜噜无码久久| 精品久久人人做人人爱| 五月婷婷丁香网| 亚洲欧美中文在线视频| 成人影视在线播放| 超碰91人人草人人干| 1区2区3区在线| 日韩免费av片在线观看| 亚洲精品成a人ⅴ香蕉片| 91久久精品一区二区别| 久久悠悠精品综合网| 日韩在线导航| 欧美一区成人| 无码精品a∨在线观看中文| 理论片日本一区| 成人在线电影网站| 久久久电影一区二区三区| 老司机成人免费视频| 午夜天堂影视香蕉久久| 中文字幕欧美人妻精品| 欧美大片免费久久精品三p| 欧美大片aaa| 久久艳片www.17c.com| 午夜久久中文| 成人性生交大片免费看小说 | 国产丝袜一区视频在线观看| 尤物在线视频| 68精品国产免费久久久久久婷婷| 久久影视精品| 国产一区喷水| 久久久五月天| 国产精品少妇在线视频| 国产aⅴ综合色| 国产免费嫩草影院| 精品国产老师黑色丝袜高跟鞋| 在线观看毛片av| 日韩电视剧在线观看免费网站| 麻豆影院在线观看| 日韩av片免费在线观看| 97久久精品| 国产精品美女在线播放| 日韩在线卡一卡二| 性欧美18—19sex性高清| 中文字幕制服丝袜一区二区三区| 色播视频在线播放| 欧美一区二区三区在线观看| 黄色在线免费观看大全| 97在线观看视频国产| 欧美区一区二区| 亚洲图片都市激情| 久久久国产精品一区二区中文| 99久久久无码国产精品性波多| **性色生活片久久毛片| 久久久久精彩视频| 亚洲精品综合久久中文字幕| 国产偷倩在线播放| 亚洲999一在线观看www| 欧美亚洲精品在线| 日本在线视频www| 99久久99久久精品免费观看| 免费三片在线播放| 欧美一二三区在线观看| 麻豆最新免费在线视频| 国产视频福利一区| 色777狠狠狠综合伊人| 国产九九在线视频| 国产亚洲欧美色| 免费又黄又爽又猛大片午夜| 日韩高清中文字幕| 超碰成人av| 国产视频一区二区不卡| 亚洲精品女人| 国产+高潮+白浆+无码| 亚洲成人自拍偷拍| 天堂在线视频观看| 97国产精品视频人人做人人爱| 国产精品香蕉| 亚洲不卡中文字幕无码| 91麻豆swag| 久久久精品视频网站| 亚洲精品一区二区在线| 成人免费无遮挡| 欧美三级网色| 视频在线观看一区| 乐播av一区二区三区| 欧美在线三级电影| 成人欧美一区| 成人a在线观看| 亚洲区综合中文字幕日日| 手机精品视频在线| 一区二区三区产品免费精品久久75| 成人av手机在线| 66m—66摸成人免费视频| 中文字幕中文字幕精品| 国产精品拍拍拍| 日韩美女视频一区| www.黄色av| 欧美性受xxxx白人性爽| 成人综合专区| 99精品视频国产| 午夜久久久久久电影| 神马久久精品| 国产精品夜间视频香蕉| 综合激情网站| 国产成人av无码精品| 一本一道综合狠狠老| 成年人免费在线视频| 亚洲综合色av| 西西人体一区二区| 影音先锋男人资源在线观看| 日韩免费看网站| 欧美黑人巨大xxxxx| 异国色恋浪漫潭| 99在线视频精品| 最新黄色网址在线观看| 欧美激情一区二区三区高清视频| 牛牛视频精品一区二区不卡| 久久久精品麻豆| 亚洲资源在线观看| 久久电影视频| av成人在线电影| 日韩中文字幕1| 久久黄色免费网站| 一区二区成人精品| 成人精品毛片| 在线免费视频一区| 亚洲国产成人精品视频| 一区二区三区视频网站| 国产精品对白刺激久久久| 日韩精品一二三区| 久久久香蕉视频| 最近2019中文字幕在线高清| ccyy激情综合| www.国产视频.com| 欧美视频第一页| 在线观看a级片| 日韩亚洲一区在线播放| 成人免费毛片片v| 国产片高清在线观看| 国产v综合ⅴ日韩v欧美大片|