成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何在JavaScript中實現隊列數據結構

開發 前端
在了解編程語言的基礎上,你還必須了解如何組織數據,以便根據任務輕松有效地操作數據。這就是數據結構的作用。

[[390111]]

在了解編程語言的基礎上,你還必須了解如何組織數據,以便根據任務輕松有效地操作數據。這就是數據結構的作用。

在這篇文章中,我將描述隊列數據結構,其具有的操作以及向您展示JavaScript中的隊列實現。

1.隊列數據結構

如果你喜歡旅行(像我一樣),很可能你在機場通過了辦理登機手續。如果有很多旅客愿意辦理登機手續,自然就會在值機柜臺前排起長龍。

剛進入機場并想要辦理登機手續的旅客將排隊進入隊列,而剛剛在服務臺辦理了登機手續的旅客則可以離開隊列。

這是隊列的真實示例—隊列數據結構以相同的方式工作。

隊列是一種“先入先出”(FIFO)數據結構的類型。入隊(輸入)的第一項是要出隊(輸出)的第一項。

從結構上說,一個隊列有2個指針。隊列中最早的排隊項目位于隊列的頂部,而最新隊列的項目位于隊列的末尾。

2.隊列中的操作

隊列主要支持兩種操作:入隊列(enqueue)和出隊列(dequeue)。此外,您可能會發現使用peek和length操作非常有用。

2.1 入隊操作

入隊操作在隊列尾部插入一個項目。

上圖中的入隊操作將項目 8 插入尾部,8 成為隊列的尾部。

  1. queue.enqueue(8); 

2.2 出隊操作

出隊操作提取隊列頭部的項,隊列中的下一項成為頭。

在上面的圖片中,出隊操作從隊列中返回并刪除項目 7,在退出隊列后,項目 2 成為新的頭。

  1. queue.dequeue(); // => 7 

2.3 Peek操作

Peek操作讀取隊列的開頭,而不會更改隊列。

項目 7 是上圖中隊列的頭部,Peek操作只是返回隊列的頭部——第 7 項,而不修改隊列。

  1. queue.peek(); // => 7 

2.4 隊列長度

長度操作計算隊列包含多少個項目。

圖片中的隊列有4個項目:4、6、2 和 7。因此,隊列長度為 4。

  1. queue.length; // => 4 

2.5 隊列操作時間復雜度

關于所有的隊列操作--enqueue、dequeue、peek和length——重要的是,所有這些操作必須在恒定的時間內 O(1) 執行。

恒定的時間 O(1) 意味著無論隊列的大小(它可以有10個或100萬個項目):enqueue、dequeue、peek和length操作必須在相對相同的時間內執行。

3.在JavaScript中實現隊列

讓我們看一下隊列數據結構的可能實現,同時維持所有操作必須在恒定時間 O(1) 中執行的要求。

  1. class Queue { 
  2.   constructor() { 
  3.     this.items = {}; 
  4.     this.headIndex = 0; 
  5.     this.tailIndex = 0; 
  6.   } 
  7.  
  8.   enqueue(item) { 
  9.     this.items[this.tailIndex] = item; 
  10.     this.tailIndex++; 
  11.   } 
  12.  
  13.   dequeue() { 
  14.     const item = this.items[this.headIndex]; 
  15.     delete this.items[this.headIndex]; 
  16.     this.headIndex++; 
  17.     return item; 
  18.   } 
  19.  
  20.   peek() { 
  21.     return this.items[this.headIndex]; 
  22.   } 
  23.  
  24.   get length() { 
  25.     return this.tailIndex - this.headIndex; 
  26.   } 
  27.  
  28. const queue = new Queue(); 
  29.  
  30. queue.enqueue(7); 
  31. queue.enqueue(2); 
  32. queue.enqueue(6); 
  33. queue.enqueue(4); 
  34.  
  35. queue.dequeue(); // => 7 
  36.  
  37. queue.peek();    // => 2 
  38.  
  39. queue.length;    // => 3 

Try the demo.

const queue = new Queue() 是創建隊列實例的方式。

調用 queue.enqueue(7) 方法會將項目7排隊到隊列中。

queue.dequeue() 從隊列中去隊列一個頭部的項目,而 queue.peek() 只是Peek頭部的項目。

最后,queue.length 顯示隊列中還有多少項目。

隊列方法的復雜性

Queue類的 queue()、dequeue()、peek() 和 length() 方法僅使用:

屬性訪問器(例如 this.items[this.headIndex] ),

或執行算術操作(例如 this.headIndex++ )

因此,這些方法的時間復雜度是恒定時間 O(1)。

總結

隊列數據結構是“先入先出”(FIFO)的一種:最早入隊的項是最早出隊的項。

隊列有2個主要操作:入隊和出隊。另外,隊列可以具有輔助操作,例如Peek和長度。

所有隊列操作必須在恒定時間 O(1) 中執行。

原文:https://dmitripavlutin.com/javascript-queue/

作者:Dmitri Pavlutin

 

責任編輯:武曉燕 來源: 前端全棧開發者
相關推薦

2022-09-01 16:27:19

JavaScriptWeb開發

2021-07-16 07:57:34

Python數據結構

2021-01-06 08:03:00

JavaScript數據結構

2022-03-31 11:17:58

JavaScript數組方法

2020-12-17 10:12:33

數據結構算法隊列

2019-08-13 09:40:55

數據結構算法JavasCript

2021-01-28 07:33:34

JavaScript鏈表數據

2011-03-21 12:41:41

JavaScript

2020-09-28 08:11:14

JavaScript數據

2021-03-09 06:30:32

JAVA數據結構算法

2020-10-28 10:10:03

Java單鏈表數據結構

2023-10-18 17:49:58

數據結構隊列結構

2021-03-11 23:43:20

JavaScript數組開發

2021-03-18 10:45:02

JavaScript數組運算符

2024-10-22 15:10:49

2022-01-21 10:58:39

JavaScriptGolangPython

2012-05-16 17:05:33

Java數據結構

2020-08-03 07:48:15

Javascript數據結構

2009-08-11 14:43:42

C#數據結構與算法

2021-03-27 11:02:04

JavaScript隊列編程語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲视频一区在线观看 | 在线观看黄色电影 | 中文字幕第5页 | 国产精品久久久久久久久久久免费看 | 国产专区视频 | 久久久女女女女999久久 | 国产一区二区在线观看视频 | 91在线视频精品 | 91高清视频在线观看 | 亚洲精品久久久久久下一站 | 伊人伊人网 | 夜夜久久 | 天堂影院av | 精品日韩一区二区三区 | 欧美456| 日韩欧美三级电影在线观看 | 日本免费一区二区三区四区 | 国产亚洲精品精品国产亚洲综合 | av大片在线观看 | 五月婷婷激情网 | 亚洲精选一区 | 一区二区三区四区视频 | 人人射人人插 | 97超碰人人| 亚洲一区在线日韩在线深爱 | 亚洲欧美日韩系列 | 欧美久久久久 | 在线欧美亚洲 | 欧美不卡网站 | 九九热这里只有精品在线观看 | 人人干97 | 欧洲尺码日本国产精品 | 一级做a爰片性色毛片视频停止 | 一区二区三区亚洲精品国 | 奇色影视| 99久久久国产精品 | 男女免费网站 | 日韩一级二级片 | 激情五月婷婷丁香 | 99热在线播放 | 成年网站在线观看 |