【LeetCode每日一题】2696. 删除子串后的字符串最小长度(调用栈)

2024-1-10

文章目录

2696. 删除子串后的字符串最小长度

思路:调用栈

1.使用双端队列实现栈

2.枚举字符串中的所有字符

3.判断当前字符和栈顶元素是否匹配.如果匹配,则弹出栈顶元素,如果不匹配,则将当前字符入栈

4.在栈中预先放入一个空字符,这样就不需要在遍历字符串时判断栈是否为空了,最后返回栈的大小减一

java 复制代码
public int minLength(String s) {
    Deque<Character> stack = new ArrayDeque<>(); // 使用双端队列实现栈
    stack.push(' '); // 在栈底添加一个空格作为哨兵元素
    for (char c : s.toCharArray()) { // 枚举字符串中的所有字符
        if ((c == 'B' && stack.peek() == 'A') || (c == 'D' && stack.peek() == 'C')) { // 判断当前字符和栈顶元素是否匹配
            stack.pop(); // 如果匹配,则弹出栈顶元素
        } else {
            stack.push(c); // 如果不匹配,则将当前字符入栈
        }
    }
    return stack.size() - 1; // 返回栈的大小减去哨兵元素的个数,即为最小长度
    }  

点击移步博客主页,欢迎光临~

相关推荐
承渊政道21 分钟前
【动态规划算法】(完全背包问题从状态定义到空间优化)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
超级大福宝23 分钟前
【力扣48. 旋转图像】超好记忆版 + 口诀
c++·算法·leetcode
爱写代码的倒霉蛋24 分钟前
2023年天梯赛L1-8
数据结构·算法
apollowing37 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(上)
算法·启发式算法·web app
生物信息与育种1 小时前
黄三文院士领衔植物星球计划(PLANeT)发表Cell
人工智能·深度学习·算法·面试·transformer
aini_lovee1 小时前
WSN 四大经典无需测距定位算法
算法
人道领域1 小时前
【LeetCode刷题日记】掌握二叉树遍历:栈实现的三种绝妙方法
算法·leetcode·职场和发展
北冥湖畔的燕雀1 小时前
深入解析Linux信号处理机制
算法
阿Y加油吧1 小时前
二刷 LeetCode:动态规划经典双题复盘
算法·leetcode·动态规划
上弦月-编程2 小时前
C语言指针超详细教程——从入门到精通(面向初学者)
java·数据结构·算法