当前位置: 首页 > news >正文

python-leetcode-压缩字符串

443. 压缩字符串 - 力扣(LeetCode)

可以使用双指针法(即一个写指针和一个读指针)来进行 原地压缩。算法的核心思想是:

  1. 遍历 chars 数组,找到连续相同的字符组。
  2. 写入字符chars 中。
  3. 如果字符重复次数大于 1,则将计数转换为字符串并写入 chars
  4. 返回最终写入的长度

代码实现如下:

def compress(chars):
    write = 0  # 记录写入的位置
    read = 0   # 记录读取的位置
    
    while read < len(chars):
        char = chars[read]  # 当前字符
        count = 0  # 记录当前字符的出现次数
        
        # 统计当前字符的连续出现次数
        while read < len(chars) and chars[read] == char:
            read += 1
            count += 1
        
        # 写入字符
        chars[write] = char
        write += 1
        
        # 如果 count > 1,则写入数字(拆分成单个字符)
        if count > 1:
            for c in str(count):
                chars[write] = c
                write += 1
    
    return write  # 返回新长度

示例

chars = ["a", "a", "b", "b", "c", "c", "c"]
new_length = compress(chars)
print(chars[:new_length])  # 输出 ['a', '2', 'b', '2', 'c', '3']

时间 & 空间复杂度

  • 时间复杂度:O(n),因为我们遍历了 chars 一次。
  • 空间复杂度:O(1),仅使用了常量额外空间(writeread 指针)。

这个方法可以在 原地 进行字符串压缩,并返回正确的新长度!🚀

相关文章:

  • c++的stl中有哪几种map容器,都有什么应用场景?
  • 【web前端开发】HTML排版标签、HTML语义化标签、常用的文本标签
  • C++11语法糖:auto和范围for循环详解
  • 面向联邦学习隐私保护的同态加密库优化算法研究
  • L1-018 大笨钟
  • java IO涉及实现的各个接口
  • AI术语整理(持续更新)
  • go语言中立即调用的匿名函数
  • 【算法day8】 Z 字形变换 -O(n)算法思路整理
  • 三角函数:从宇宙法则到AI革命的数学密钥
  • Git 高级指南:完整命令大全及进阶用法
  • Python Web项目的服务器部署
  • golang从入门到做牛马:第十五篇-Go语言切片(Slice):动态数组的“魔法”
  • 基于WPF的雷达上位机系统开发实践
  • 「AI 加持的高效架构」高并发场景下的服务器成本优化
  • 如何更有效管理项目风险
  • 数据类设计_图片类设计之4_规则类图形混合算法(前端架构)
  • CSDN博客:Markdown编辑语法教程总结教程(下)
  • AF3 make_fixed_size函数解读
  • 类与对象(一)
  • 女生“生理期请病假要脱裤子证明”?高校回应:视频经处理后有失真等问题
  • 俄媒:俄乌代表团抵达谈判会场
  • 乌克兰谈判代表团由12人组成,乌防长率领
  • 丰富“互换通”产品类型,促进中国金融市场高水平对外开放
  • 浙能集团原董事长童亚辉被查,还是杭州市书法家协会主席
  • 崔登荣任国家游泳队总教练