博客
关于我
【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/

    你可能感兴趣的文章
    notepad++最详情汇总
    查看>>
    notepad++正则表达式替换字符串详解
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notes on Paul Irish's "Things I learned from the jQuery source" casts
    查看>>
    Notification 使用详解(很全
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    NotImplementedError: Could not run torchvision::nms
    查看>>
    nova基于ubs机制扩展scheduler-filter
    查看>>
    Now trying to drop the old temporary tablespace, the session hangs.
    查看>>
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>
    npm ERR! ERESOLVE could not resolve报错
    查看>>
    npm ERR! fatal: unable to connect to github.com:
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near '...on":"0.10.3","direc to'
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near ‘...“:“^1.2.0“,“vue-html-‘ npm ERR! A comp
    查看>>
    npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
    查看>>