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

LeetCode 1750.删除字符串两端相同字符后的最短长度

题目

给你一个只包含字符 'a''b' 和 'c' 的字符串 s ,你可以执行下面这个操作(5 个步骤)任意次:

  1. 选择字符串 s 一个 非空 的前缀,这个前缀的所有字符都相同。
  2. 选择字符串 s 一个 非空 的后缀,这个后缀的所有字符都相同。
  3. 前缀和后缀在字符串中任意位置都不能有交集。
  4. 前缀和后缀包含的所有字符都要相同。
  5. 同时删除前缀和后缀。

请你返回对字符串 s 执行上面操作任意次以后(可能 0 次),能得到的 最短长度 。

思路

代码

class Solution {
    public int minimumLength(String s) {
        int n = s.length();
        int left = 0, right = n - 1;
        while (left < right && s.charAt(left) == s.charAt(right)) {
            char c = s.charAt(left);
            while (left <= right && s.charAt(left) == c) {
                left++;
            }
            while (left <= right && s.charAt(right) == c) {
                right--;
            }
        }
        return right - left + 1;
    }
}

性能

时间复杂度o(n)

空间复杂度o(1)


http://www.kler.cn/news/361919.html

相关文章:

  • centOS部署Jenkins实现项目可持续自动化部署
  • Windows系统启动MongoDB报错无法连接服务器
  • 《黑神话悟空》各章节boss顺序汇总
  • 电机编码器
  • element-时间选择器单独写两个时间选择器并按照规则进行置灰选择,精确到时分秒
  • eCAP超声波测距-ePWM电机调速
  • Lattice_FPGA使用Synplify Pro进行综合
  • flv格式如何转换mp4?将flv转换成MP4格式的9种转换方法
  • 如何将 Elasticsearch 与流行的 Ruby 工具结合使用
  • Linux下进行用户的切换与创建以及细微设置
  • SIMPLOT: Enhancing Chart Question Answering by Distilling Essentials
  • LeetCode两数相加
  • ECharts饼图-饼图标签对齐,附视频讲解与代码下载
  • 情怀程序员,没有套路的坐下和大家掏心窝聊聊今年的1024 | 程序员节
  • 通过DevTools逃离Chrome沙盒(CVE-2024-6778和CVE-2024-5836)
  • 删除本地文件不影响Github
  • Centos7 安装部署Zookeeper
  • AMR机器人助力废料管理,实现生产空间最大化利用
  • 五年以上倾斜摄影osgb模型转3dtiles如何在mars3d加载
  • CSS 设置网页的背景图片
  • Spearman、Pearson、Euclidean、Cosine、Jaccard,用来衡量不同数据之间的相似性或差异性
  • 【Linux】从 fork() 到 exec():理解 Linux 进程程序替换的魔法
  • gbn,sr和tcp的区别
  • Oracle VM的网络中桥接网卡找不到网络
  • UEFI EDK2框架学习 (四)——UEFI图形化
  • 设计模式05-创建型模式(建造者/原型/单例模式/Java)