Fork me on GitHub

压缩字符串

leetcode:443.压缩字符串

给定一组字符,使用原地算法将其压缩。

压缩后的长度必须始终小于或等于原数组长度。

数组的每个元素应该是长度为1 的字符(不是 int 整数类型)。

在完成原地修改输入数组后,返回数组的新长度。

进阶:
你能否仅使用O(1) 空间解决问题?

示例 1:

输入:
[“a”,”a”,”b”,”b”,”c”,”c”,”c”]

输出:
返回6,输入数组的前6个字符应该是:[“a”,”2”,”b”,”2”,”c”,”3”]

说明:
“aa”被”a2”替代。”bb”被”b2”替代。”ccc”被”c3”替代。

示例 2:

输入:
[“a”]

输出:
返回1,输入数组的前1个字符应该是:[“a”]

说明:
没有任何字符串被替代。

示例 3:

输入:
[“a”,”b”,”b”,”b”,”b”,”b”,”b”,”b”,”b”,”b”,”b”,”b”,”b”]

输出:
返回4,输入数组的前4个字符应该是:[“a”,”b”,”1”,”2”]。

说明:
由于字符”a”不重复,所以不会被压缩。”bbbbbbbbbbbb”被“b12”替代。
注意每个数字在数组中都有它自己的位置。

注意:
所有字符都有一个ASCII值在[35, 126]区间内。
1 <= len(chars) <= 1000。

思路:
用一个index作为输出指针,将字母计数后,再进行输入,使用to_string函数可以很方便地将整型的各数位分离。最后要删除尾巴,用erase即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
class Solution {
public:
int compress(vector<char>& chars) {
//如果只有一个字符,你就返回当前元素个数
if(chars.size() <= 1){
return chars.size();
}

int index = 0;
for(int i = 0; i < chars.size(); i++){
int count = 1;
chars[index++] = chars[i];
while(i+1 < chars.size() && chars[i] == chars[i+1]){
count++;
i++;
}

//判断count是否大于1
if(count > 1){
string s = to_string(count);
for(int k = 0; k < s.size(); k++){
chars[index++] = s[k];
}
}
}
//原地压缩,将后边的数据擦除
chars.erase(chars.begin()+index,chars.end());
return chars.size();
}
};
-------------本文结束感谢您的阅读-------------

本文标题:压缩字符串

文章作者:李煜哲

发布时间:2018年12月01日 - 17:12

最后更新:2018年12月01日 - 17:12

原始链接:http://yoursite.com/2018/12/01/压缩字符串/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者

觉得好的话就打赏一下吧