当前位置: 首页 > news >正文

【LeetCode2696】删除子串后的字符串最小长度

1、题目描述

【题目链接】
标签:字符串模拟
难度:简单
给你一个仅由 大写 英文字符组成的字符串 s 。
你可以对此字符串执行一些操作,在每一步操作中,你可以从 s 中删除 任一个 “AB” 或 “CD” 子字符串。
通过执行操作,删除所有 “AB” 和 “CD” 子串,返回可获得的最终字符串的 最小 可能长度。
注意,删除子串后,重新连接出的字符串可能会产生新的 “AB” 或 “CD” 子串。

示例 1:
输入:s = “ABFCACDB”
输出:2
解释:你可以执行下述操作:

  • 从 “ABFCACDB” 中删除子串 “AB”,得到 s = “FCACDB” 。
  • 从 “FCACDB” 中删除子串 “CD”,得到 s = “FCAB” 。
  • 从 “FCAB” 中删除子串 “AB”,得到 s = “FC” 。
    最终字符串的长度为 2 。
    可以证明 2 是可获得的最小长度。

示例 2:
输入:s = “ACBBD”
输出:5
解释:无法执行操作,字符串长度不变。

提示:
1 <= s.length <= 100
s 仅由大写英文字母组成

2、基本思路

 这是一道简单的字符串处理的题目,可以用栈模型上述的删除的过程即可,值得注意的是,删除子串后,重新连接出的字符串可能会产生新的 “AB” 或 “CD” 子串。

下面是利用栈对示例 1 模拟的过程:

  • 初始化栈空;
  • 栈空,A入栈;
  • 当前元素B,与栈顶元素A,构成子串AB,A出栈;
  • 栈空,F入栈;
  • 当前元素C,栈顶元素F,构不成子串,C入栈;
  • 当前元素A,栈顶元素C,构不成子串,A入栈;
  • 当前元素C,栈顶元素A,构不成子串,C入栈;
  • 当前元素D,栈顶元素C,构成子串CD,C出栈;
  • 当前元素B,栈顶元素A,构成子串AB,A出栈;
  • 字符串元素遍历完毕,栈中元素的长度即为答案;

3、代码实现


int minLength(string s) {stack<char> st;for(int i = 0;i<s.length();++i){char c = s[i];if(st.empty())st.push(c);else{if(c=='D'&&st.top()=='C')st.pop();else if(c=='B'&&st.top()=='A')st.pop();elsest.push(c);}}return st.size();    
}
http://www.lryc.cn/news/280368.html

相关文章:

  • VMware安装CentOS7虚拟机
  • Linux第22步_安装CH340驱动和串口终端软件MobaXterm
  • Elasticsearch 地理空间搜索 - 远超 OpenSearch
  • USB micro输入口中三个问题详解——差分信号、自恢复保险丝SMD1210P050TF、电容滤波
  • mysql原理--undo日志1
  • Zookeeper系列(一)集群搭建(非容器)
  • 【高等数学之泰勒公式】
  • 奇异值分解在图形压缩中的应用
  • C++深入学习之STL:1、容器部分
  • Javascript——vue下载blob文档流
  • C# 的SequenceEqual
  • 第九部分 使用函数 (一)
  • 【JUC进阶】14. TransmittableThreadLocal
  • 基于C++的ORM框架sqlpp11入门介绍(附MySQL运行实例)
  • 对写文章的想法
  • Istio安装和基础原理
  • C++核心编程——基于多态的企业职工系统
  • Nginx服务安装
  • 微信小程序canvas画布实现矩形元素自由缩放、移动功能
  • 一文搞懂 Python 3 中的数据类型
  • 学习笔记之——3D Gaussian Splatting源码解读
  • Flink standalone集群部署配置
  • Python: + 运算符、append() 方法和 extend()方法的区别和用法
  • 【MySQL】mysql集群
  • zabbix监控windows主机
  • 单例模式的八种写法、单例和并发的关系
  • 基于实时Linux+FPGA实现NI CompactRIO系统详解
  • Webhook端口中的自定义签名身份认证
  • 用Linux的视角来理解缓冲区概念
  • C#中Enumerable.Range(Int32, Int32) 方法用于计算