隊列與堆棧類似,只是插入點與移除點不同。
我們在隊列的一端添加,從另一端移除。
這一次,我們稱之為先進先出(FIFO)。
就像你能想到的任何隊列一樣,例如在餐廳、迪廳或者當你在等待進入音樂廳時。
這是在JAVAScript中使用私有類字段,使用數組作為內部存儲的隊列的實現。
class Queue {
#items = []
enqueue = (item) => this.#items.splice(0, 0, item)
dequeue = () => this.#items.pop()
isempty = () => this.#items.length === 0
empty = () => (this.#items.length = 0)
size = () => this.#items.length
}
下面是如何使用它:首先從類中初始化一個對象,然后調用它的方法。
- enqueue() 來添加項目
- dequeue()從隊列中取出一個項目。
例如:
const queue = new Queue()
queue.enqueue(1)
queue.enqueue(2)
queue.enqueue(3)
queue.size() //3
queue.dequeue() //1
queue.dequeue() //2
queue.dequeue() //3