欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)

這篇文章主要介紹了JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)的相關(guān)知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)文章都會有所收獲,下面我們一起來看看吧。

創(chuàng)新互聯(lián)建站始終堅持【策劃先行,效果至上】的經(jīng)營理念,通過多達10多年累計超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的全網(wǎng)整合營銷推廣解決方案,現(xiàn)已廣泛運用于各行各業(yè)的客戶,其中包括:服務(wù)器托管等企業(yè),備受客戶贊譽。

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

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

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

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

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

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

2.隊列中的操作

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

2.1 入隊操作

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

JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)

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

queue.enqueue(8);

2.2 出隊操作

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

JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)

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

queue.dequeue(); // => 7

2.3 Peek操作

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

JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)

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

queue.peek(); // => 7

2.4 隊列長度

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

JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)

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

queue.length; // => 4

2.5 隊列操作時間復(fù)雜度

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

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

3.在JavaScript中實現(xiàn)隊列

讓我們看一下隊列數(shù)據(jù)結(jié)構(gòu)的可能實現(xiàn),同時維持所有操作必須在恒定時間 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)建隊列實例的方式。

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

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

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

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

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

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

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

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

關(guān)于“JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)”知識都有一定的了解,大家如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享題目:JavaScript隊列數(shù)據(jù)結(jié)構(gòu)如何實現(xiàn)
當前地址:http://www.chinadenli.net/article18/pgcddp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)動態(tài)網(wǎng)站營銷型網(wǎng)站建設(shè)外貿(mào)網(wǎng)站建設(shè)外貿(mào)建站網(wǎng)站維護

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)