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

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

相关推荐
ULTRA??几秒前
QT向量类实现GJK碰撞检测算法3d版本
c++·qt·算法
天赐学c语言4 分钟前
12.10 - 合并两个有序链表 && 对字节对齐的理解
数据结构·c++·leetcode·链表
仰泳的熊猫6 分钟前
1092 To Buy or Not to Buy
数据结构·c++·算法·pat考试
罗湖老棍子11 分钟前
【深基16.例3】二叉树深度(洛谷P4913)
数据结构·算法·二叉树
Charlo16 分钟前
Open-AutoGLM Windows 安装部署教程
算法·设计模式·github
君义_noip26 分钟前
信息学奥赛一本通 4017:【GESP2309三级】小杨的储蓄 | 洛谷 B3867 [GESP202309 三级] 小杨的储蓄
c++·算法·gesp·信息学奥赛
高山上有一只小老虎39 分钟前
判断是否为数独数组
java·算法
宝贝儿好1 小时前
【强化学习】第二章:老虎机问题、ε-greedy算法、指数移动平均
人工智能·python·算法
CoovallyAIHub1 小时前
超越深度学习:量子优化如何通过算法与硬件重塑AI
深度学习·算法·计算机视觉