C语言 | Leetcode C语言题解之第443题压缩字符串

题目:

题解:

cpp 复制代码
void swap(char *a, char *b) {
    char t = *a;
    *a = *b, *b = t;
}

void reverse(char *a, char *b) {
    while (a < b) {
        swap(a++, --b);
    }
}

int compress(char *chars, int charsSize) {
    int write = 0, left = 0;
    for (int read = 0; read < charsSize; read++) {
        if (read == charsSize - 1 || chars[read] != chars[read + 1]) {
            chars[write++] = chars[read];
            int num = read - left + 1;
            if (num > 1) {
                int anchor = write;
                while (num > 0) {
                    chars[write++] = num % 10 + '0';
                    num /= 10;
                }
                reverse(&chars[anchor], &chars[write]);
            }
            left = read + 1;
        }
    }
    return write;
}
相关推荐
多米Domi01121 小时前
0x3f 第20天 三更24-32 hot100子串
java·python·算法·leetcode·动态规划
能量鸣新1 天前
资源分享第三天
c语言·开发语言·c++·python·计算机视觉·c#
漫随流水1 天前
leetcode算法(344.反转字符串)
数据结构·算法·leetcode
POLITE31 天前
Leetcode 2.两数相加 JavaScript (Day 11)
前端·javascript·leetcode
sin_hielo1 天前
leetcode 1411(递推)
数据结构·算法·leetcode
iAkuya1 天前
(leetcode)力扣100 32随机链表的复制(回溯+哈希/迭代+节点拆分)
leetcode·链表·哈希算法
YGGP1 天前
【Golang】LeetCode 1351. 统计有序矩阵中的负数
leetcode·矩阵
漫随流水1 天前
leetcode算法(20.有效的括号)
数据结构·算法·leetcode
一路往蓝-Anbo1 天前
STM32单线串口通讯实战(一):物理层拓扑与STM32G0硬件配置
c语言·开发语言·stm32·单片机·嵌入式硬件·物联网
im_AMBER1 天前
Leetcode 94 合并零之间的节点
数据结构·c++·笔记·学习·算法·leetcode