农场里有一群牛,农夫为了方便管理,给每头牛都编了号,用字符来表示。现在农夫想要统计农场里每种牛的数量,但是由于数量过多,农夫想要将连续的相同的牛的数量进行压缩表示。请你帮助农夫完成这个任务。 给你一个字符数组 cows ,请使用下述算法压缩: 从一个空字符串 s 开始。对于 cows 中的每组 连续重复字符 : 如果这一组长度为 1 ,则将字符追加到 s 中,不作其他改变 否则,需要向 s 追加字符,后跟这一组的长度。 压缩后得到的字符串 s 不应该直接返回 ,需要转储到字符数组 cows 中。需要注意的是,如果组长度为 10 或 10 以上,则数字在 cows 数组中会被拆分为多个字符。 请在 修改完输入数组后 ,返回该数组的新长度。 你必须设计并实现一个只使用常量额外空间的算法来解决此问题。
示例1

输入

[x,x,y,y,z,z,z]

输出

[x,2,y,2,z,3]

说明

"xx" 被 "x2" 替代。"yy" 被 "y2" 替代。"zzz" 被 "z3" 替代。
示例2

输入

[a,b,b,b,b,b,b,b,b,b,b,b,b]

输出

[a,b,1,2]

说明

由于字符 "a" 不重复,所以不会被压缩。"bbbbbbbbbbbb" 被 “b12” 替代。

备注:
1 cows[i] 可以是小写英文字母、大写英文字母、数字或符号
加载中...