0
点赞
收藏
分享

微信扫一扫

【leetcode刷题笔记】2.用两个栈实现队列(简单)

小猪肥 2022-02-16 阅读 33
leetcode

题目如下:

第一次尝试:

思路:在第一个栈插入元素,在第二个栈删除元素。想要插入元素直接在栈A中push()即可,想要删除元素时,将A中的元素pop()再push()进B,就可以实现队列的效果。

注意:

  1. 用js来写时注意写this。
  2. 由于是栈数据结构,因此只能使用pop()和push(),不要使用别的方法。
  3. 删除元素时一次性将A中的元素全部压入B,这样之后删除时操作B即可,不需要重复压入元素(因此deleteHead函数中是否压入使用了while而不是一次性判断if)。

代码如下:

var CQueue = function() {
    this.stackA = [];
    this.stackB = [];
};

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

/**
 * @return {number}
 */
CQueue.prototype.deleteHead = function() {
    if(this.stackB.length){
        return this.stackB.pop();
    }else{
        while(this.stackA.length){
            this.stackB.push(this.stackA.pop());
        };
        if(!this.stackB.length){
            return -1;
        }else{
            return this.stackB.pop();
        };
    };
};
举报

相关推荐

0 条评论