代码随想录二刷第九天 | 232.用栈实现队列、225. 用队列实现栈、20. 有效的括号、1047. 删除字符串中的所有相邻重复项

232.用栈实现队列

题目:232. 用栈实现队列 - 力扣(LeetCode)

题解:代码随想录

状态:AC

思路

两个栈,一个用于入队stackIn,一个用于出队stackOut。

push时直接进入stackIn,pop时要讨论,stackOut不为空直接pop,否则将stackIn整体放到stackOut

代码

java 复制代码
class MyQueue {
    Stack<Integer> stackIn = new Stack<>();
    Stack<Integer> stackOut = new Stack<>();
    
    public MyQueue() {
        stackIn = new Stack<>();
        stackOut = new Stack<>();
    }
    
    public void push(int x) {
        stackIn.push(x);
    }
    
    public int pop() {
        copy();
        return stackOut.pop();
    }
    
    public int peek() {
        copy();
        return stackOut.peek();
    }

    public void copy(){
        if(!stackOut.isEmpty()) return;
        while(!stackIn.isEmpty()){
            stackOut.push(stackIn.pop());
        }
    }
    
    public boolean empty() {
        return stackOut.isEmpty() && stackIn.isEmpty();
    }
}

225. 用队列实现栈

题目:225. 用队列实现栈 - 力扣(LeetCode)

题解:代码随想录

状态:AC

思路

用一个队列实现,每次出栈时都把需要弹出元素之外的其余元素重新入队。

代码

java 复制代码
class MyStack {
    Queue<Integer> queue;
    
    public MyStack() {
        queue = new LinkedList<>();
    }
    
    public void push(int x) {
        queue.add(x);
    }
    
    public int pop() {
        rePosition();
        return queue.poll();
    }
    
    public int top() {
        rePosition();
        int result = queue.poll();
        queue.add(result);
        return result;
    }
    
    public boolean empty() {
        return queue.isEmpty();
    }

    public void rePosition(){
        int size = queue.size();
        size--;
        while(size-->0)
            queue.add(queue.poll());
    }
}

20. 有效的括号

题目:20. 有效的括号 - 力扣(LeetCode)

题解:代码随想录

状态:AC

思路

利用栈的先入后出性质即可解决。

不过要注意栈为空push右括号和最后栈不为空的情况。

代码

时间复杂度:O(n) 空间复杂度:O(n)

java 复制代码
class Solution {
    public boolean isValid(String s) {
        Stack<Character> stack = new Stack<>();
        for (int i = 0; i < s.length(); i++) {
            char cur = s.charAt(i);
            if (cur == '(' || cur == '{' || cur == '[') {
                stack.push(cur);
            } else {
                if (stack.isEmpty()) return false;
                char popChar = stack.pop();
                if ((top == '(' && c != ')')
                 || (top == '{' && c != '}')
                 || (top == '[' && c != ']')) {
                    return false;
                }
            }
        }

        return stack.isEmpty();
    }
}

1047. 删除字符串中的所有相邻重复项

题目:1047. 删除字符串中的所有相邻重复项 - 力扣(LeetCode)

题解:代码随想录

状态:AC

思路

利用栈的性质即可解决。

代码

时间复杂度:O(n) 空间复杂度:O(n)

java 复制代码
class Solution {
    public String removeDuplicates(String s) {
        Stack<Character> stack = new Stack<>();
        for(int i = 0; i < s.length(); i++){
            char cur = s.charAt(i);
            if(stack.isEmpty()){
                stack.push(cur);
            }else{
                if(stack.peek() == cur){
                    stack.pop();
                }else{
                    stack.push(cur);
                }
            }
        }
        String res = "";
        while(!stack.isEmpty()){
            res = stack.pop().toString() + res;
        }
        return res;
    }
}
相关推荐
一定要AK8 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao8 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
KevinCyao8 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
迷藏4948 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
wuxinyan12310 小时前
Java面试题47:一文深入了解Nginx
java·nginx·面试题
新知图书10 小时前
搭建Spring Boot开发环境
java·spring boot·后端
冰河团队10 小时前
一个拉胯的分库分表方案有多绝望?整个部门都在救火!
java·高并发·分布式数据库·分库分表·高性能
洛_尘10 小时前
Java EE进阶:Linux的基本使用
java·java-ee
宸津-代码粉碎机10 小时前
Spring Boot 4.0虚拟线程实战调优技巧,最大化发挥并发优势
java·人工智能·spring boot·后端·python
MaCa .BaKa10 小时前
47-心里健康咨询平台/心理咨询系统
java·spring boot·mysql·tomcat·maven·intellij-idea·个人开发