91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中怎么實現一個隊列數據結構

發布時間:2021-07-01 18:10:49 來源:億速云 閱讀:185 作者:Leah 欄目:web開發

這篇文章將為大家詳細講解有關JavaScript中怎么實現一個隊列數據結構,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

1.隊列數據結構

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

JavaScript中怎么實現一個隊列數據結構

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

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

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

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

2.隊列中的操作

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

2.1 入隊操作

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

JavaScript中怎么實現一個隊列數據結構

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

queue.enqueue(8);

2.2 出隊操作

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

JavaScript中怎么實現一個隊列數據結構

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

queue.dequeue(); // => 7

2.3 Peek操作

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

JavaScript中怎么實現一個隊列數據結構

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

queue.peek(); // => 7

2.4 隊列長度

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

JavaScript中怎么實現一個隊列數據結構

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

queue.length; // => 4

2.5 隊列操作時間復雜度

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

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

3.在JavaScript中實現隊列

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

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() 是創建隊列實例的方式。

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

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

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

隊列方法的復雜性

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

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

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

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

關于JavaScript中怎么實現一個隊列數據結構就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

鹿邑县| 惠州市| 富源县| 峨眉山市| 邵武市| 安新县| 安福县| 莎车县| 昭觉县| 乌兰县| 海丰县| 偃师市| 瑞昌市| 阿拉善盟| 深水埗区| 凯里市| 江西省| 栾城县| 蒙阴县| 古交市| 东乡县| 泽库县| 永泰县| 靖远县| 克什克腾旗| 宁晋县| 资溪县| 曲阜市| 祁阳县| 高青县| 青浦区| 绩溪县| 和林格尔县| 鹤山市| 云和县| 翼城县| 天水市| 衡阳市| 东乌珠穆沁旗| 内黄县| 宿松县|