LeetCode 面试题 01.06. 字符串压缩
一、题目
字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串 aabcccccaaa
会变为 a2b1c5a3
。若“压缩”后的字符串没有变短,则返回原先的字符串。你可以假设字符串中只包含大小写英文字母(a至z)。
示例1:
输入:“aabcccccaaa”
输出:“a2b1c5a3”
示例2:
输入:“abbccd”
输出:“abbccd”
解释:“abbccd"压缩后为"a1b2c2d1”,比原字符串长度更长。
提示:
- 字符串长度在[0, 50000]范围内。
二、C# 题解
题目比较简单,使用双指针即可,不多赘述:
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)。