1078 字符串压缩与解压 (20分)
文本压缩有很多种方法,这里我们只考虑最简单的一种:把由相同字符组成的一个连续的片段用这个字符和片段中含有这个字符的个数来表示。例如 ccccc 就用 5c 来表示。如果字符没有重复,就原样输出。例如 aba 压缩后仍然是 aba。
解压方法就是反过来,把形如 5c 这样的表示恢复为 ccccc。
本题需要你根据压缩或解压的要求,对给定字符串进行处理。这里我们简单地假设原始字符串是完全由英文字母和空格组成的非空字符串。
输入格式:
输入第一行给出一个字符,如果是 C 就表示下面的字符串需要被压缩;如果是 D 就表示下面的字符串需要被解压。第二行给出需要被压缩或解压的不超过 1000 个字符的字符串,以回车结尾。题目保证字符重复个数在整型范围内,且输出文件不超过 1MB。
输出格式:
根据要求压缩或解压字符串,并在一行中输出结果。
思路:分别写出压缩和解压函数,如果是压缩,分别对比上一个和当前,如果连续相同,则++,解压就逐个检索,如果是数字,就记录并进行相应count操作,如果不是,就判断count值输出
#include <stdio.h>
void zip()
{
char previous = getchar(), current;
int count = 1;
while((current = getchar()))
{
if(current == previous)
{
count++; //如果当前和上一个相同,count++
}
else
{
if(count > 1)
printf("%d", count);
putchar(previous);
previous = current;
count = 1;
}
if(current == '\n') //不能放进while循环
break;
}
}
void unzip()
{
char c;
int count = 0;
while((c = getchar()) != '\n')
{
if(c >= '0' && c <= '9') //如果是数字
{
count = count * 10 + c - '0';
}
else //如果不是数字
{
if(count == 0) //如果字符前没有数字
count = 1; //就打印一次
for(int i = 0; i < count; i++) //否则,就打印count次
putchar(c);
count = 0; //重置count
}
}
}
int main()
{
switch(getchar())
{
case 'C':
while(getchar() != '\n');
zip();
break;
case 'D':
while(getchar() != '\n');
unzip();
break;
default:
break;
}
return 0;
}