算法训练(leetcode)二刷第九天 | 232. 用栈实现队列、225. 用队列实现栈、20. 有效的括号、1047. 删除字符串中的所有相邻重复项

刷题记录

  • [232. 用栈实现队列](#232. 用栈实现队列)
  • [225. 用队列实现栈](#225. 用队列实现栈)
  • [20. 有效的括号](#20. 有效的括号)
  • [1047. 删除字符串中的所有相邻重复项](#1047. 删除字符串中的所有相邻重复项)

232. 用栈实现队列

leetcode题目地址

栈与队列的存储顺序相反,因此用两个栈来实现队列。

时间复杂度: pop、peek是 O ( n ) O(n) O(n),push、empty是 O ( 1 ) O(1) O(1)
空间复杂度: O ( n ) O(n) O(n)

java 复制代码
// java

class MyQueue {

    Stack<Integer> stIn;
    Stack<Integer> stOut;


    public MyQueue() {
        stIn = new Stack<>();
        stOut = new Stack<>();
    }
    
    public void push(int x) {
        stIn.push(x);
    }
    
    public int pop() {
        int x;
        x = peek();
        stOut.pop();
        return x;
    }
    
    public int peek() {
        int x;
        if(stOut.isEmpty()){
            while(!stIn.isEmpty()){
                x = stIn.peek();
                stOut.push(x);
                stIn.pop();
            }
        }
        return stOut.peek();
    }
    
    public boolean empty() {
        return (stOut.isEmpty() && stIn.isEmpty());
    }
}

/**
 * Your MyQueue object will be instantiated and called as such:
 * MyQueue obj = new MyQueue();
 * obj.push(x);
 * int param_2 = obj.pop();
 * int param_3 = obj.peek();
 * boolean param_4 = obj.empty();
 */

225. 用队列实现栈

leetcode题目地址

同上题,两个队列实现栈。

略有不同之处是:取栈顶操作。需要先将quIn中的n-1个元素移出,剩余的一个元素即为栈顶。

**Tricks:**因为队列的先入先出特点,导致两个队列中的顺序是一致的,因此将元素始终存储在一个队列中,在移动过后交换两者的地址即可,无需再进行一次移动。

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

java 复制代码
// java
class MyStack {
    Queue<Integer> quIn;
    Queue<Integer> quOut;


    public MyStack() {
        quIn = new LinkedList<>();
        quOut = new LinkedList<>();
    }
    
    public void push(int x) {
        quIn.add(x);
    }
    
    public int pop() {
        int size = quIn.size()-1;
        while(size-->0){
            quOut.offer(quIn.poll());
        }
        int x = quIn.poll();
        // trick
        Queue<Integer> tmp = quOut;
        quOut = quIn;
        quIn = tmp;
        return x;
    }
    
    public int top() {
        int size = quIn.size()-1;
        while(size-->0){
            quOut.offer(quIn.poll());
        }
        int x = quIn.poll();
        quOut.offer(x);
        // trick
        Queue<Integer> tmp = quOut;
        quOut = quIn;
        quIn = tmp;
        return x;
    }
    
    public boolean empty() {
        return quIn.isEmpty();
    }
}

/**
 * Your MyStack object will be instantiated and called as such:
 * MyStack obj = new MyStack();
 * obj.push(x);
 * int param_2 = obj.pop();
 * int param_3 = obj.top();
 * boolean param_4 = obj.empty();
 */

20. 有效的括号

leetcode题目地址

左括号入栈,右括号进行匹配,失配返回false。最终栈非空返回false,为空则意味着匹配成功返回true。

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

java 复制代码
// java
class Solution {
    public boolean isValid(String s) {
        Stack<Character> st = new Stack<>();
        boolean flag = true;
        for(int i=0; i<s.length(); i++){
            if(s.charAt(i)=='(' || s.charAt(i)=='[' || s.charAt(i)=='{'){
                st.push(s.charAt(i));
            }else{

                if(!st.isEmpty() && s.charAt(i)==')' && st.peek() == '(') st.pop();
                else if(!st.isEmpty() && s.charAt(i)==']' && st.peek() == '[') st.pop();
                else if(!st.isEmpty() && s.charAt(i)=='}' && st.peek() == '{') st.pop();
                else return false;
            }
        }
        return st.isEmpty();
    }
}

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

leetcode题目地址

借助栈,删除相邻的重复项。返回剩余字符时栈内弹出顺序是逆序,因此需要进行反转。

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

java 复制代码
// java
class Solution {
    public String removeDuplicates(String s) {
        Stack<Character> st = new Stack<>();
        for(int i=0; i<s.length(); i++){
            char ch = s.charAt(i);
            if(!st.isEmpty() && st.peek() == ch){
                st.pop();
            }else{
                st.push(ch);
            }
        }
        StringBuilder sb = new StringBuilder();
        while(!st.isEmpty()){
            sb.append(st.pop());
        }
        return sb.reverse().toString();
    }
}
相关推荐
波波0072 分钟前
每日一题:.NET 中什么是 LOH(大对象堆)?为什么频繁使用大数组或大字符串可能导致性能问题?如何优化?
java·jvm·算法
独自破碎E3 分钟前
动态规划-正则表达式匹配
算法·正则表达式·动态规划
Gofarlic_OMS3 分钟前
Fluent许可证使用合规性报告自动化生成系统
java·大数据·运维·人工智能·算法·matlab·自动化
漫随流水4 分钟前
leetcode回溯算法(131.分割回文串)
数据结构·算法·leetcode·回溯算法
我家大宝最可爱7 分钟前
强化学习基础-重要性采样
算法·机器学习·概率论
Remember_99310 分钟前
文件系统与IO操作:深入解析与Java实践
java·开发语言·数据结构·ide·python·算法
大江东去浪淘尽千古风流人物17 分钟前
【DSP】DSP核心组件 SM算法部署
算法
努力学习的小廉20 分钟前
我爱学算法之—— 递归
算法·深度优先
Mixtral4 小时前
2026年春招复盘记录工具测评:告别手动整理,AI自动生成求职总结
人工智能·面试·职场和发展·语音转文字·ai语音转文字
一个不知名程序员www8 小时前
算法学习入门 --- 哈希表和unordered_map、unordered_set(C++)
c++·算法