【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; // 返回栈的大小减去哨兵元素的个数,即为最小长度
    }  

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

相关推荐
老鼠只爱大米4 分钟前
LeetCode算法题详解 53:最大子数组和
leetcode·动态规划·分治法·最大子数组和·kadane算法·maxsubarray
小欣加油5 分钟前
leetcode 面试题17.16 按摩师
数据结构·c++·算法·leetcode·动态规划
飞Link10 分钟前
数据合成中的通用模型蒸馏、领域模型蒸馏和模型自我提升
算法·数据挖掘
夏鹏今天学习了吗11 分钟前
【LeetCode热题100(80/100)】完全平方数
算法·leetcode·职场和发展
sin_hielo12 分钟前
leetcode 3454(扫描线模板题:矩形面积并)
数据结构·算法·leetcode
a程序小傲15 分钟前
中国邮政Java面试被问:Kafka的Log Compaction实现和删除策略
java·开发语言·后端·python·面试·职场和发展·kafka
地球资源数据云20 分钟前
1960年-2024年中国农村居民消费价格指数数据集
大数据·数据库·人工智能·算法·数据集
爱编程的小吴1 小时前
【力扣练习题】167. 两数之和 II - 输入有序数组
算法·leetcode·职场和发展
sunfove1 小时前
打破物理与算法的边界:超分辨率成像原理深度解析
算法·成像·超分辨城乡
wearegogog1238 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab