日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何在JavaScript中實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

在了解編程語言的基礎(chǔ)上,你還必須了解如何組織數(shù)據(jù),以便根據(jù)任務(wù)輕松有效地操作數(shù)據(jù)。這就是數(shù)據(jù)結(jié)構(gòu)的作用。

為靖宇等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及靖宇網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站建設(shè)、網(wǎng)站制作、靖宇網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

在這篇文章中,我將描述隊(duì)列數(shù)據(jù)結(jié)構(gòu),其具有的操作以及向您展示JavaScript中的隊(duì)列實(shí)現(xiàn)。

1.隊(duì)列數(shù)據(jù)結(jié)構(gòu)

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

剛進(jìn)入機(jī)場并想要辦理登機(jī)手續(xù)的旅客將排隊(duì)進(jìn)入隊(duì)列,而剛剛在服務(wù)臺辦理了登機(jī)手續(xù)的旅客則可以離開隊(duì)列。

這是隊(duì)列的真實(shí)示例—隊(duì)列數(shù)據(jù)結(jié)構(gòu)以相同的方式工作。

隊(duì)列是一種“先入先出”(FIFO)數(shù)據(jù)結(jié)構(gòu)的類型。入隊(duì)(輸入)的第一項(xiàng)是要出隊(duì)(輸出)的第一項(xiàng)。

從結(jié)構(gòu)上說,一個(gè)隊(duì)列有2個(gè)指針。隊(duì)列中最早的排隊(duì)項(xiàng)目位于隊(duì)列的頂部,而最新隊(duì)列的項(xiàng)目位于隊(duì)列的末尾。

2.隊(duì)列中的操作

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

2.1 入隊(duì)操作

入隊(duì)操作在隊(duì)列尾部插入一個(gè)項(xiàng)目。

上圖中的入隊(duì)操作將項(xiàng)目 8 插入尾部,8 成為隊(duì)列的尾部。

 
 
 
 
  1. queue.enqueue(8); 

2.2 出隊(duì)操作

出隊(duì)操作提取隊(duì)列頭部的項(xiàng),隊(duì)列中的下一項(xiàng)成為頭。

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

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

2.3 Peek操作

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

項(xiàng)目 7 是上圖中隊(duì)列的頭部,Peek操作只是返回隊(duì)列的頭部——第 7 項(xiàng),而不修改隊(duì)列。

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

2.4 隊(duì)列長度

長度操作計(jì)算隊(duì)列包含多少個(gè)項(xiàng)目。

圖片中的隊(duì)列有4個(gè)項(xiàng)目:4、6、2 和 7。因此,隊(duì)列長度為 4。

 
 
 
 
  1. queue.length; // => 4 

2.5 隊(duì)列操作時(shí)間復(fù)雜度

關(guān)于所有的隊(duì)列操作--enqueue、dequeue、peek和length——重要的是,所有這些操作必須在恒定的時(shí)間內(nèi) O(1) 執(zhí)行。

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

3.在JavaScript中實(shí)現(xiàn)隊(duì)列

讓我們看一下隊(duì)列數(shù)據(jù)結(jié)構(gòu)的可能實(shí)現(xiàn),同時(shí)維持所有操作必須在恒定時(shí)間 O(1) 中執(zhí)行的要求。

 
 
 
 
  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() 是創(chuàng)建隊(duì)列實(shí)例的方式。

調(diào)用 queue.enqueue(7) 方法會將項(xiàng)目7排隊(duì)到隊(duì)列中。

queue.dequeue() 從隊(duì)列中去隊(duì)列一個(gè)頭部的項(xiàng)目,而 queue.peek() 只是Peek頭部的項(xiàng)目。

最后,queue.length 顯示隊(duì)列中還有多少項(xiàng)目。

隊(duì)列方法的復(fù)雜性

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

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

或執(zhí)行算術(shù)操作(例如 this.headIndex++ )

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

總結(jié)

隊(duì)列數(shù)據(jù)結(jié)構(gòu)是“先入先出”(FIFO)的一種:最早入隊(duì)的項(xiàng)是最早出隊(duì)的項(xiàng)。

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

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

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

作者:Dmitri Pavlutin


當(dāng)前文章:如何在JavaScript中實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu)
URL標(biāo)題:http://www.5511xx.com/article/djjgohj.html