232. 用栈实现队列 JavaScript实现

232. 用栈实现队列

题目链接

一、思想

  1. 将一个栈当作输入栈,用于压入 push 传入的数据;另一个栈当作输出栈,用于pop和peek 操作。
  2. 每次 pop 或peek时,若输出栈为空则将输入栈的全部数据依次弹出并压入输出栈,这样输出栈从栈顶往栈底的顺序就是队列从队首往队尾的顺序。

二、代码实现

// 面对对象编程
var MyQueue = function() {
    // 定义两个栈,用数组实现栈的操作
    this.inputStack = [],
    this.outputStack = [];
};

// 入队,即将数据压入输入栈中
MyQueue.prototype.push = function(x) {
    this.inputStack.push(x);
};

// 从队头移除并返回元素,即当输出栈为空的时候,将输入栈的元素弹出并且压入输出栈中
// 这里需要用if,因为只需要得到一个元素
MyQueue.prototype.pop = function() {
    if(!this.outputStack.length){
        this.out_to_in();
    }
    return this.outputStack.pop();
};

// 返回队头的元素,即和pop()的作用一致,只是不删除元素
MyQueue.prototype.peek = function() {
    if(!this.outputStack.length){
        this.out_to_in();
    }
    return this.outputStack[this.outputStack.length-1];   
};

// 当输入栈不空的时候,将输入栈的元素弹出,压到输出栈中
// 注意这里要用while,因为可能之前在输入栈中压入了多个元素,如果只操作一个元素,得到的并不是队头的元素
MyQueue.prototype.out_to_in = function(){
    while(this.inputStack.length){
        let x = this.inputStack.pop();
        this.outputStack.push(x);
    }
}

// 检查队列是否为空,即检查输入栈和输出栈是否均为空
MyQueue.prototype.empty = function() {
    if(this.inputStack.length == 0 && this.outputStack.length == 0) return true;
    return false;
};

/**
 * Your MyQueue object will be instantiated and called as such:
 * var obj = new MyQueue()
 * obj.push(x)
 * var param_2 = obj.pop()
 * var param_3 = obj.peek()
 * var param_4 = obj.empty()
 */
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值