LeetCode 面试题 01.06. 字符串压缩

文章目录

一、题目

  字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串 aabcccccaaa 会变为 a2b1c5a3。若"压缩"后的字符串没有变短,则返回原先的字符串。你可以假设字符串中只包含大小写英文字母(a至z)。

  点击此处跳转题目

示例1:

输入:"aabcccccaaa"

输出:"a2b1c5a3"

示例2:

输入:"abbccd"

输出:"abbccd"

解释:"abbccd"压缩后为"a1b2c2d1",比原字符串长度更长。

提示:

  • 字符串长度在0, 50000范围内。

二、C# 题解

  题目比较简单,使用双指针即可,不多赘述:

csharp 复制代码
public class Solution {
    public string CompressString(string S) {
        StringBuilder sb = new StringBuilder(S.Length * 2); // 预留 S.Length * 2 的空间,避免重新分配
        int i = 0, j = 0; // 双指针,i 指向第一个不重复字符,j 寻找后方第一个不同字符
        
        while (i < S.Length) {
            sb.Append(S[i]);                        // 压入 i
            while (++j < S.Length && S[j] == S[i]); // 更新 j
            sb.Append(j - i);                       // 压入 出现次数
            i = j;                                  // 更新 i
        }

        return sb.Length < S.Length ? sb.ToString() : S; // 依据要求返回值
    }
}
  • 时间复杂度: O ( n ) O(n) O(n)。
  • 空间复杂度: O ( n ) O(n) O(n)。
相关推荐
想吃火锅100514 分钟前
【leetcode】88.合并两个有序数组js
算法
生成论实验室1 小时前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres8211 小时前
算法复键——树状数组
数据结构·算法
H178535090961 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
dayuOK63071 小时前
写作卡壳怎么办?我的“5分钟启动法”
人工智能·职场和发展·自动化·新媒体运营·媒体
不会就选b1 小时前
算法日常・每日刷题--<二分查找>3
算法
2601_962072551 小时前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
枫子有风2 小时前
LLM-Agent智能体(大厂面试常问)
面试·职场和发展·llm·agent
绿算技术2 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构
-森屿安年-2 小时前
63. 不同路径 II
c++·算法·动态规划