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

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

相关推荐
颜酱6 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub9 小时前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub10 小时前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub10 小时前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub10 小时前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub10 小时前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP21 小时前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP21 小时前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮21 小时前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法