真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

這篇文章將為大家詳細(xì)講解有關(guān)JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

成都創(chuàng)新互聯(lián)公司主營羅田網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app軟件開發(fā),羅田h5微信小程序定制開發(fā)搭建,羅田網(wǎng)站營銷推廣歡迎羅田等地區(qū)企業(yè)咨詢

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

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

JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

剛進(jìn)入機(jī)場(chǎng)并想要辦理登機(jī)手續(xù)的旅客將排隊(duì)進(jìn)入隊(duì)列,而剛剛在服務(wù)臺(tái)辦理了登機(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)。此外,您可能會(huì)發(fā)現(xiàn)使用peek和length操作非常有用。

2.1 入隊(duì)操作

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

JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

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

queue.enqueue(8);

2.2 出隊(duì)操作

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

JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

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

queue.dequeue(); // => 7

2.3 Peek操作

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

JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

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

queue.peek(); // => 7

2.4 隊(duì)列長度

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

JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)

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

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操作必須在相對(duì)相同的時(shí)間內(nèi)執(zhí)行。

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

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

class Queue {   constructor() {     this.items = {};     this.headIndex = 0;     this.tailIndex = 0;   }    enqueue(item) {     this.items[this.tailIndex] = item;     this.tailIndex++;   }    dequeue() {     const item = this.items[this.headIndex];     delete this.items[this.headIndex];     this.headIndex++;     return item;   }    peek() {     return this.items[this.headIndex];   }    get length() {     return this.tailIndex - this.headIndex;   } }  const queue = new Queue();  queue.enqueue(7); queue.enqueue(2); queue.enqueue(6); queue.enqueue(4);  queue.dequeue(); // => 7  queue.peek();    // => 2  queue.length;    // => 3

Try the demo.

const queue = new Queue() 是創(chuàng)建隊(duì)列實(shí)例的方式。

調(diào)用 queue.enqueue(7) 方法會(huì)將項(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)。

關(guān)于JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


分享名稱:JavaScript中怎么實(shí)現(xiàn)一個(gè)隊(duì)列數(shù)據(jù)結(jié)構(gòu)
網(wǎng)頁路徑:http://weahome.cn/article/gihdoi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部