剑指 Offer丨 9. 用两个栈实现队列(JavaScript版本)

题目: 用两个栈实现队列

  • 用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )
  • 提示
    • 1 <= values <= 10000
    • 最多会对 appendTail、deleteHead 进行 10000 次调用

题解

  • 思路:
    • 1.创建两个栈(instack,outstack),利用栈【先进后出】,队列【先进先出】
    • 2.appendTail:栈和队列都是先进,所以利用入栈的数组(instack)push实现
    • 3.deleteHead:
      • (1)先判断用于出栈的数组是否有值(outstack.length
      • (2) 因为栈【后出】,队列【先出】。所以将入栈的数组pop出的数值push给出栈数组(this.outstack.push(this.instack.pop())),实现逆置,则出栈数组pop出的数值就是队头的数值。
      • (3)最后返回值需要判断出栈的数组是否有值,不为空则返回队头的数值,为空则返回-1;return this.outstack.length?this.outstack.pop():-1;
  • 代码:
var CQueue = function() {
    this.instack = [];
    this.outstack = [];
};

/** 
 * @param {number} value
 * @return {void}
 */
CQueue.prototype.appendTail = function(value) {
    this.instack.push(value);
};

/**
 * @return {number}
 */
CQueue.prototype.deleteHead = function() {
    if(!this.outstack.length){
        while(this.instack.length){
            this.outstack.push(this.instack.pop())
        }
    }
    return this.outstack.length?this.outstack.pop():-1;
};

/**
 * Your CQueue object will be instantiated and called as such:
 * var obj = new CQueue()
 * obj.appendTail(value)
 * var param_2 = obj.deleteHead()
 */
  • 复杂度分析:
    • 时间复杂度:appendTail 为 O(1),deleteHead 为均摊O(1)。对于每个元素,至多入栈和出栈各两次,故均摊复杂度为 O(1)O(1)。
    • 空间复杂度:O(n)。其中 nn 是操作总数。对于有 n 次 appendTail 操作的情况,队列中会有 n 个元素,故空间复杂度为 O(n)
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值