代码随想录LeetCode | 栈与队列相关题目

目录

题目回顾

相关章节

方法论:

1.栈与队列理论基础

栈:先进后出

队列:先进先出

2.232. 用栈实现队列

3.225. 用队列实现栈

总结


前沿:撰写博客的目的是为了再刷时回顾进一步完善,其次才是以教为学,所以如果有些博客写的较简陋,是为了保持进度不得已而为之,还请大家多多见谅。

预:看到题目后的思路和实现的代码。

见:参考答案展示。

感思:对比答案后的思考,与之前做过的题目是否有关联。

行:

(1)对于没做出来的题目,阅读答案后重新做一遍;

(2)下次做题可以尝试改善的方向;

(3)有助于理解的相关的题目

优先级:做题进度>学习&总结>默写回顾>做题数量

题目回顾

 

相关章节

方法论:

1.栈与队列理论基础

知识链接:栈与队列理论基础

栈:先进后出

Stack<Integer> stack = new Stack<>(); push/peek/pop/isEmpty/size();

目前Java一般使用Deque,stack被弃用了,其继承的vector都被弃用了。

因为vector和stack类都是jdk1.0时的产物较为粗糙,当时stack类的创建是为了实现栈的功能,当时是想复用简单的方法才选择继承vector类的,其与vector类基本没啥关系,但也能够使用vector其他无关的大量方法,有点四不像;并且因为底层实现是数组,当大小不够时仍需要扩容。

Deque<Integer> deque = new ArrayDeque<>();

ArrayDeque是Deque接口的具体实现,其依赖于可变数组,所以在效率上会更好一些stack,同时具备stack的push和pop函数。

队列:先进先出

Queue的实现类有 LinkedList 和 PriorityQueue;

Queue<Integer> queue = new LinkedList(); offer/top/poll/isEmpty/size();

2.232. 用栈实现队列

题目链接:232. 用栈实现队列

通过两个栈分别作为输入和输出栈,当要求展示队列头时

1.输出栈存在值,则返回输出栈顶peek 2.输出栈为空时,则将输入栈全部存入输出栈中,再返回栈顶peek。

class MyQueue {
    Stack<Integer> stackIn;
    Stack<Integer> stackOut;
    public MyQueue() {
        stackIn = new Stack<>();
        stackOut = new Stack<>();
    }
    
    public void push(int x) {
        stackIn.push(x);
    }
    public void getValue(){
        if(stackOut.empty()){
            while(!stackIn.empty()){
                stackOut.push(stackIn.pop());
            }
        }
    }
    public int pop() {
        getValue();
        return stackOut.pop();        
    }
    
    public int peek() {
        getValue();
        return stackOut.peek();
    }
    
    public boolean empty() {
        if(stackIn.empty() && stackOut.empty()){
            return true;
        }else{
            return false;
        }
    }
}

3.225. 用队列实现栈

题目链接:225. 用队列实现栈

通过一个队列模拟栈

当队列为空值,直接存入值。

队列不为空值,len = queue.size()记录队列长度,再存入新值,将旧值都出队列再输入回来。

class MyStack {
    Queue<Integer> queue;
    public MyStack() {
        queue = new LinkedList();
    }
    
    public void push(int x) {
        Queue<Integer> temp = new LinkedList();
        if(queue.isEmpty()){
            queue.offer(x);
        }else{
            temp.offer(x);
            while(!queue.isEmpty()){
                temp.offer(queue.poll());
            }
            queue = temp;
        }
    }
    
    public int pop() {
        return queue.poll();
    }
    
    public int top() {
        return queue.peek();
    }
    
    public boolean empty() {
        return queue.isEmpty();
    }
}

总结

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值