队列与堆栈类似,只是插入点与移除点不同。
我们在队列的一端添加,并从另一端移除。
这一次,我们称之为先进先出(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