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)。
相关推荐
sp_fyf_202411 分钟前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸31 分钟前
链表的归并排序
数据结构·算法·链表
jrrz082832 分钟前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time43 分钟前
golang学习2
算法
面试鸭1 小时前
离谱!买个人信息买到网安公司头上???
java·开发语言·职场和发展
南宫生2 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步2 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
Ni-Guvara3 小时前
函数对象笔记
c++·算法
测试19983 小时前
2024软件测试面试热点问题
自动化测试·软件测试·python·测试工具·面试·职场和发展·压力测试