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)。
相关推荐
LYFlied7 分钟前
【每日算法】LeetCode 25. K 个一组翻转链表
算法·leetcode·链表
Swizard12 分钟前
别再迷信“准确率”了!一文读懂 AI 图像分割的黄金标尺 —— Dice 系数
python·算法·训练
s090713616 分钟前
紧凑型3D成像声纳实现路径
算法·3d·声呐·前视多波束
可爱的小小小狼17 分钟前
算法:二叉树遍历
算法
d111111111d1 小时前
在STM32函数指针是什么,怎么使用还有典型应用场景。
笔记·stm32·单片机·嵌入式硬件·学习·算法
AI科技星2 小时前
质量定义方程常数k = 4π m_p的来源、推导与意义
服务器·数据结构·人工智能·科技·算法·机器学习·生活
摇摆的含羞草2 小时前
哈希(hash)算法使用特点及常见疑问解答
算法·哈希算法
仰泳的熊猫3 小时前
1077 Kuchiguse
数据结构·c++·算法·pat考试
LYFlied3 小时前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
踏浪无痕3 小时前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试