国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

如何使用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

2012-12-17 13:51:22

Web前端JavaScriptJS

2016-11-30 18:35:03

JavaScript

2025-03-07 11:06:06

大型語言模型AICoD

2009-06-24 15:00:39

Javascript代
點贊
收藏

51CTO技術棧公眾號

免费日韩一区二区| 中文字幕一区二区不卡| 亚洲美女性视频| 奇米影音第四色| 国v精品久久久网| 欧洲在线视频一区| 亚洲高清二区| 91精品综合视频| 水蜜桃精品av一区二区| 国产精品电影观看| 宅男在线一区| 国产99久久精品一区二区永久免费| 99a精品视频在线观看| 少妇av一区二区三区| 成人精品三级| 深夜福利国产精品| 日韩欧美精品电影| 亚洲三级av在线| 中文字幕在线官网| 国产亚洲精品美女| av一区在线播放| 中文字幕亚洲综合久久筱田步美| 第四色男人最爱上成人网| 亚洲欧美日韩精品久久| 国产精品高清乱码在线观看| 色噜噜久久综合伊人一本| 青青国产精品| 高清欧美性猛交xxxx黑人猛交| 成人知道污网站| 国产精品久久久久秋霞鲁丝 | 国产日韩精品一区观看| 欧美日韩亚洲一区三区| 久草精品电影| 韩国午夜理伦三级不卡影院| av网站手机在线观看| 国产亚洲欧美一级| 羞羞网站在线观看入口免费| 亚洲国产aⅴ成人精品无吗| 伊人75在线| 日韩欧美亚洲国产精品字幕久久久 | 国产精品一区二区三区四区色| 成人18视频日本| 四虎影院观看视频在线观看 | 3d玉蒲团在线观看| 国产精品果冻传媒潘| 一区二区三区四区高清精品免费观看 | 欧美精品不卡| 在线观看高清av| 日本欧美一二三区| 久久狠狠亚洲综合| 尤物网站在线| 日韩在线播放av| 欧美一区影院| 国产亚洲精品网站| 日韩成人中文字幕| 在线午夜精品| xxxxx日韩| 97av在线视频| 99麻豆久久久国产精品免费 | 国产成人tv| 成人h猎奇视频网站| 99精品视频在线观看免费播放 | 日本三级黄色网址| 久久久久久久免费| 制服丝袜成人动漫| 青青草视频在线观看| 午夜a成v人精品| 国产原创一区| 成人久久一区二区| 在线中文字幕一区二区| 欧美日韩一本| www.日本三级| 99久久婷婷国产| 中文字幕一区二区三区免费视频| 成人午夜电影网站| 国产二区视频在线播放| 91国偷自产一区二区三区成为亚洲经典| 99蜜月精品久久91| 国产尤物av一区二区三区| 欧美精品一区二区三区精品| 91九色单男在线观看| 精品国产成人在线| 性高湖久久久久久久久| 91精品尤物| 日本成人一区二区三区| 亚洲在线视频一区二区| 亚洲三级 欧美三级| 亚洲一区av在线| 久久99精品国产麻豆不卡| 欧美三级电影在线| 日本三级视频在线观看| 美女三级99| 91蝌蚪国产九色| aaaa欧美| 黄色无遮挡网站| 国产精品视频一区二区三区四| 亚洲欧美激情视频在线观看一区二区三区 | 麻豆电影传媒二区| 日韩亚洲国产欧美| 色视频网站在线| 精品亚洲一区二区| 欧美激情在线| 欧美色老女人| 精品国产一区二区三区在线观看 | 精品久久av| 国产综合在线视频| 国产大陆精品国产| 午夜影院免费在线| 国产福利久久精品| 一区二区三区日韩在线观看| 福利一区在线| 中文一区一区三区免费| 欧美美女激情18p| 欧美在线色图| youjizzxxxx18| 久久精品久久精品亚洲人| 国产综合久久久久久鬼色| jizz在线免费观看| 91精品天堂| 狠狠色狠色综合曰曰| 亚洲婷婷伊人| 15—17女人毛片| 欧美男插女视频| 久久久久久久久久美女| 日韩免费在线电影| 国产白丝袜美女久久久久| 亚洲欧美中文日韩在线| 国产综合久久久久久久久久久久| 2020av在线| 一本色道久久88亚洲精品综合| 精品国产一区二区亚洲人成毛片| 免费视频久久| brazzers在线观看| 影音先锋成人资源网站| 337p日本欧洲亚洲大胆精品| 亚洲一区二区三区高清不卡| 成年人黄视频在线观看| 亚洲国产精品一区在线观看不卡| 亚洲黄色www| 成人av电影免费在线播放| 国产精品成人3p一区二区三区| 亚洲国产精品毛片av不卡在线| 欧美激情在线有限公司| 亚洲色图制服丝袜| 欧美好骚综合网| 二区三区在线| 手机看片福利永久国产日韩| 亚洲欧美制服丝袜| 久久精品一区蜜桃臀影院| 精品三级av| 在线黄色av| 欧美日韩精品免费观看| 亚洲女人天堂av| 久久久久久久一区| 成人嫩草影院| 亚洲小说区图片| 少妇高潮毛片色欲ava片| 91爱爱小视频k| 色综合久久天天| 日韩电影一区二区三区四区| 97久久网站| 日本fc2在线观看| 国产精品一区二区免费看| 精品毛片乱码1区2区3区| 不卡的av网站| 精品久久成人| 性欧美1819sex性高清大胸| 久久久成人精品一区二区三区| 成人444kkkk在线观看| 一区二区三区欧美激情| 免费在线亚洲欧美| 国产视频一区二区在线播放| 视频三区在线观看| 国内精品国产三级国产99| 奇米成人av国产一区二区三区| 欧美性大战久久久久久久蜜臀| 国产一区免费电影| 亚洲尤物av| 日本不卡影院| 三级在线免费看| 麻豆成人在线播放| 久久久久久久久国产| 欧美日韩视频一区二区| www.激情成人| 欧美一区视频| 91麻豆精品| av一本在线| www.com黄色片| 欧美一级片免费观看| 欧美大成色www永久网站婷| 在线视频欧美精品| 99re成人在线| 国产日韩欧美三级| 久久激情av| 亚洲欧洲自拍| 国产一区精品| 台湾十八成人网| 亚洲啊啊啊啊啊| 国产精品福利视频| 热99在线视频|