博客
关于我
【Leetcode】1544. Make The String Great
阅读量:526 次
发布时间:2019-03-07

本文共 1709 字,大约阅读时间需要 5 分钟。

解析字符串处理问题:递归删除特定字符子串

问题描述

给定一个仅包含英文字母的字符串,要求递归删除所有满足以下条件的相邻字符对:这对字符分别是某个字母的不同大小写形式。具体而言,若字符串中存在相邻两个字符,一个为大写字母,另一个为小写字母,且它们的字母相同,则这对字符可以被删除。处理完成后,返回最终的字符串结果。题目保证答案唯一。

代码解析

为了实现上述功能,以下Java代码提供了一种解决方案:

public class Solution {    public String makeGood(String s) {        StringBuilder sb = new StringBuilder();        for (int i = 0; i < s.length(); i++) {            char ch = s.charAt(i);            if (sb.length() > 0 && Math.abs(sb.charAt(sb.length() - 1) - ch) == 'a' - 'A') {                sb.setLength(sb.length() - 1);            } else {                sb.append(ch);            }        }        return sb.toString();    }}

工作原理

  • StringBuilder初始化:使用StringBuilder来构建结果字符串,确保字符操作的高效性。
  • 遍历字符串:逐个字符遍历输入字符串。
  • 字符比较:对于当前字符ch,检查StringBuilder的最后一个字符sb.charAt(sb.length() - 1)
    • 条件满足:如果两个字符的ASCII码差的绝对值等于32(即'a' - 'A'),说明它们是一个大写字母和一个小写字母,且字母相同。此时,删除StringBuilder的最后一个字符。
    • 条件不满足:否则,将当前字符追加到StringBuilder中。
  • 返回结果:遍历结束后,返回StringBuilder构建的字符串。
  • 代码正确性验证

    为了确认代码的正确性,我们可以通过多个示例进行验证:

  • 示例1:输入字符串为"AbBA"

    • 处理过程:
      • A添加,sb = "A"
      • bAb的ASCII码差为33,不满足条件,追加,sb = "Ab"
      • BbB的ASCII码差为32,满足条件,删除Bsb = "A".
      • AAA的ASCII码差为0,不满足条件,追加,sb = "AA"
    • 结果:"AA"
  • 示例2:输入字符串为"aBcAb"

    • 处理过程:
      • a添加,sb = "a"
      • BaB的ASCII码差为31,不满足条件,追加,sb = "aB"
      • cBc的ASCII码差为34,不满足条件,追加,sb = "aBc"
      • AcA的ASCII码差为33,不满足条件,追加,sb = "aBcA"
      • bAb的ASCII码差为33,不满足条件,追加,sb = "aBcAb"
    • 结果:"aBcAb"
  • 示例3:输入字符串为"BabA"

    • 处理过程:
      • B添加,sb = "B"
      • aBa的ASCII码差为32,满足条件,删除asb = "B"
      • bBb的ASCII码差为32,满足条件,删除bsb = "B"
      • ABA的ASCII码差为1,不满足条件,追加,sb = "BA"
    • 结果:"BA"
  • 优化分析

    时间复杂度

    代码遍历字符串一次,时间复杂度为O(n),其中n是字符串的长度。空间复杂度同样为O(n),因为StringBuilder用于存储结果字符串。

    优缺点

    • 优点:代码简洁,时间复杂度高效,空间复杂度线性。
    • 缺点:在某些情况下,可能会错误地删除不符合条件的字符对。

    总结

    通过上述分析,可以确认提供的代码能够正确地处理字符串中的相邻字符对,删除符合条件的字符子串。该算法的时间和空间复杂度均为O(n), 使其在处理较长字符串时表现优异。

    转载地址:http://trfnz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置——不记录指定文件类型日志
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>