我有很长的整数序列,看起来像这样(任意长度!):
0000000001110002220033333
现在我需要一些算法来将此字符串转换为压缩的东西
a9b3a3c3a2d5
这意味着“a 9 次,然后 b 3 次,然后 a 3 次”等等,其中“a”代表 0,“b”代表 1,“c”代表 2,“d”代表 3。
你会怎么做?到目前为止,我没有想到任何合适的东西,而且我在谷歌上没有运气,因为我真的不知道要搜索什么。这种编码/压缩叫什么?
PS:我打算用PHP编码,用JavaScript解码。
编辑:谢谢大家!
我最终得到了这个编码功能:
protected function numStringToRle($s){
$rle = '';
$count = 1;
$len = strlen($s);
for($i = 0; $i < $len; $i++){
if($i != $len && isset($s[$i+1]) && $s[$i] == $s[$i+1]){
$count++;
} else {
$rle .= chr($s[$i] + 97).( $count == 1 ? '' : $count);
$count = 1;
}
}
return $rle;
}
而用于解码:
var decodeCoords = function(str) {
str = str.replace(/(.)(\d+)/g, function(_, x, n) {
return new Array(parseInt(n, 10) + 1).join(x);
});
return str.
replace(/a/g, '0').
replace(/b/g, '1').
replace(/c/g, '2').
replace(/d/g, '3');
};