字符串压缩

题目链接

字符串压缩

题目描述

注意点

  • 字符串长度在[0, 50000]范围内
  • 若"压缩"后的字符串没有变短,则返回原先的字符串
  • 字符串中只包含小写英文字母(a至z)

解答思路

  • 模拟思路,使用pre存储当前位置的前一个字符,使用sum存储前一个字符重复的数量,当访问到当前位置的字符c时,如果c和pre相同,则只需要将sum加1,如果c和pre不同,则需要先将pre的数量写到结果中,然后将c写到结果中,还要更新pre和sum的值

代码

java 复制代码
class Solution {
    public String compressString(String s) {
        StringBuilder sb = new StringBuilder();
        char pre = '0';
        int sum = 0;
        for (char c : s.toCharArray()) {
            if (c == pre) {
                sum++;
                continue;
            }
            if (sum != 0) {
                sb.append(sum);
            }
            sb.append(c);
            pre = c;
            sum = 1;
        }
        if (sum != 0) {
            sb.append(sum);
        }
        return sb.length() >= s.length() ? s : sb.toString();
    }
}

关键点

  • 注意遍历完字符串后,还要将最后的字符的出现次数写入到结果中
相关推荐
OtIo TALL16 小时前
redis7 for windows的安装教程
java
Sam_Deep_Thinking16 小时前
学数据结构到底有什么用
数据结构
kobesdu16 小时前
人形机器人SLAM:技术挑战、算法综述与开源方案
算法·机器人·人形机器人
uNke DEPH16 小时前
Spring Boot的项目结构
java·spring boot·后端
xixingzhe217 小时前
idea启动vue项目
java·vue.js·intellij-idea
wzl2026121317 小时前
企业微信定时群发技术实现与实操指南(原生接口+工具落地)
java·运维·前端·企业微信
凌波粒17 小时前
Java 8 “新”特性详解:Lambda、函数式接口、Stream、Optional 与方法引用
java·开发语言·idea
曹牧17 小时前
Eclipse:悬停提示(Hover)
java·ide·eclipse
oyzz12018 小时前
Spring EL 表达式的简单介绍和使用
java·后端·spring
椰羊~王小美18 小时前
随机数概念及算法
算法