js数据结构学习---队列

2.队列

受限的线性表,先进先出

  • 表的前端进行删除操作

  • 表的后端进行插入操作

2.1队列的常见操作

  • enqueue(element):向队列尾部添加一个(或多个)新的项

  • dequeue():移除队列的第一(即排在队列最前面的)项,并返回被移除的元素

  • front():返回队列中第一个元素--最先被添加,也将是最先被移除的元素。队列中不做任何变动(不移除元素,只返回元素信息与stack类的peek方法类似)

  • isEmpty():如果队列中不包含任何元素,返回true,否则返回false

  • size():返回队列包含的元素个数,与数组的length属性类似

  • toString():将队列中的内容,转成字符串形式

2.2列队操作的实践

//封装队列类
function Queue () {
    this.list = []
    //向队列尾部添加一个或多个新项
    Queue.prototype.enqueue = function (element) {
        this.list.push(element)
    }
    //移除队首元素
    Queue.prototype.dequeue = function () {
        return this.list.shift()
    }
    Queue.prototype.front = function () {
        return this.list[0]
    }
    Queue.prototype.isEmpty = function () {
        if (this.list.length == 0)
            return false
        else return true
    }
    Queue.prototype.size = function () {
        return this.list.length
    }
    Queue.prototype.toString = function () {
        return this.list.toString()
    }
​
}

2.3经典面试题

击鼓传花

function gu () {
    for (var i = 0; i < list.length; i++)
        queue.enqueue(list[i])
    var count = 0
    while (queue.size() > 1) {
        count++
        if (count != 5) {
            a = queue.dequeue()
            queue.enqueue(a)
        }
        else {
            queue.dequeue()
            count = 0
        }
    }
    console.log(queue)
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

进阶的菜熊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值