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)。
相关推荐
u***276130 分钟前
C#数据库操作系列---SqlSugar完结篇
网络·数据库·c#
fengfuyao98536 分钟前
竞争性自适应重加权算法(CARS)的MATLAB实现
算法
散峰而望38 分钟前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
leoufung39 分钟前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
wyhwust1 小时前
交换排序法&冒泡排序法& 选择排序法&插入排序的算法步骤
数据结构·算法·排序算法
利刃大大1 小时前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包
wyhwust2 小时前
数组----插入一个数到有序数列中
java·数据结构·算法
笑非不退2 小时前
C# c++ 实现程序开机自启动
开发语言·c++·c#
im_AMBER2 小时前
Leetcode 59 二分搜索
数据结构·笔记·学习·算法·leetcode
gihigo19982 小时前
基于MATLAB的IEEE 14节点系统牛顿-拉夫逊潮流算法实现
开发语言·算法·matlab