文本压缩有很多种方法,这里我们只考虑最简单的一种:把由相同字符组成的一个连续的片段用这个字符和片段中含有这个字符的个数来表示。例如 ccccc 就用 5c 来表示。如果字符没有重复,就原样输出。例如 aba 压缩后仍然是 aba。

解压方法就是反过来,把形如 5c 这样的表示恢复为 ccccc。

本题需要你根据压缩或解压的要求,对给定字符串进行处理。这里我们简单地假设原始字符串是完全由英文字母和空格组成的非空字符串。

输入格式:

输入第一行给出一个字符,如果是 C 就表示下面的字符串需要被压缩;如果是 D 就表示下面的字符串需要被解压。第二行给出需要被压缩或解压的不超过1000个字符的字符串,以回车结尾。题目保证字符重复个数在整型范围内,且输出文件不超过1MB。

输出格式:

根据要求压缩或解压字符串,并在一行中输出结果。

输入样例 1:

C
TTTTThhiiiis isssss a tesssst CAaaa as

输出样例 1:

5T2h4is i5s a3 te4st CA3a as

输入样例 2:

D
5T2h4is i5s a3 te4st CA3a as10Z

输出样例 2:

TTTTThhiiiis isssss a   tesssst CAaaa asZZZZZZZZZZ

本文需要注意的是aaa的情况,其他的基本能过
 // 1078.cpp : 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include<iostream>
#include<string>
#include<cstdlib>
#include<stack> using namespace std; //将字母的个数置于字符串中
void get_num(int &num,string &str2,const string &str,int &i)
{
stack<int> s; if (num != )
{
while (num)//将数字分别压入栈中
{
s.push(num % );
num /= ;
} while (!s.empty())
{
str2 += (char)(s.top() + );
s.pop();
} } str2.append(, str[i - ]);
num = ;
} void Zip()
{
string str, str2;
getline(cin, str);
int size = str.size(), num = ; for (int i = ; i<size; ++i)
{
if (str[i] == str[i - ])
{
num++; if (i == size - )
get_num(num,str2,str,i);
}
else
{
get_num(num, str2, str, i); if (i == size - )
str2.append(, str[i]);
}
} cout << str2 << endl;
} bool isdigit(char c)
{
if (c <= ''&&c >= '')
return true;
else
return false;
} void Unzip()
{
string str, str2;
getline(cin, str);
int size = str.size(); for (int i = ; i<size; ++i)
{
if (isdigit(str[i]))//如果为数字求得该数字
{
int num = , j;
for (j = i; isdigit(str[j]); ++j)
{
num *= ;
num += str[j] - ;
} str2.append(num, str[j]);
i = j; //刷新i
}
else
str2.append(, str[i]);
} cout << str2 << endl;
} int main()
{
char ch = getchar();
getchar(); if (ch == 'C')
Zip();
else
Unzip(); return ;
}

最新文章

  1. WPF Datagrid删除一行
  2. [TCPIP] 传输控制协议 Note
  3. GitHub的使用之新建与更新代码
  4. git冲突解决
  5. python实现动态更新远程机器列表的SSH登录脚本
  6. VS2015发布Webservice
  7. html添加keyword,description帮助百度收录处理方法,jsp去除空白行方法
  8. SDPLR的安装过程(matlab)
  9. SqlServer sysobjects_table
  10. Lua学习----零碎知识点
  11. [Swift]LeetCode881. 救生艇 | Boats to Save People
  12. IAR Embedded Workbench for ARM 8.22.1 基础使用教程
  13. PS扣签名
  14. easyui 布局之window和panel一起使用时,拉动window宽高时panel不跟随一起变化
  15. Python Redis 管道
  16. linux安装node简单方法
  17. Verdi文档路径
  18. OneZero第二周第一次站立会议(2016.3.28)
  19. jQuery 效果 - slideToggle() 方法
  20. MVVM的本质:视图逻辑处理、视图管理、视数中间层

热门文章

  1. PTA 6-12 (二叉树的递归删除)
  2. MyBatis 遍历数组放入in中
  3. web四则混合运算2
  4. 为移动端而设计的bootstrap的使用
  5. eclipse项目版本控制忽略上传文件
  6. myBatis框架的配置部分
  7. SQL Server 并发死锁解决案例备忘
  8. haproxy prometheus 监控docker-compose 运行试用
  9. lapis 项目添加prometheus 监控
  10. JS正则表达式验证身份证号码