压缩(compress)
测试数据来自 wjszez/2139
【问题描述】
给一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中的重复信息。压缩后的字符串除了小写字母外还可以(但不必)包含大写字母R与M,其中M标记重复串的开始,R重复从上一个M(如果当前位置左边没有M,则从串的开始算起)开始的解压结果(称为缓冲串)。
bcdcdcdcd可以压缩为bMcdRR,下面是解压缩的过程:
已经解压的部分 解压结果 缓冲串
b b b
bM b
bMc bc c
bMcd bcd cd
bMcdR bcdcd cdcd
bMcdRR bcdcdcdcd cdcdcdcd
另一个例子是abcabcdabcabcdxyxyz可以被压缩为abcRdRMxyRz。
【输入格式】
输入仅一行,包含待压缩字符串,仅包含小写字母,长度为n。
【输出格式】
输出仅一行,即压缩后字符串的最短长度。
【输入输出样例】
输入样例1:
aaaaaaa
输出样例1:
5
输入样例2:
bcdcdcdcdxcdcdcdcd
输出样例2:
12
样例说明:
在第一个例子中,解为aaaRa,在第二个例子中,解为bMcdRRxMcdRR。
数据限制:
50%的数据满足:1<=n<=20
100%的数据满足:1<=n<=50
信息
- ID
- 2175
- 难度
- (无)
- 分类
- (无)
- 标签
- 递交数
- 0
- 已通过
- 0
- 通过率
- ?
- 上传者