编码 分而治之
来源:互联网 发布:百度百科如何优化 编辑:程序博客网 时间:2024/05/18 01:29
编码
Time Limit: 1000MS Memory Limit: 65536KB
Submit Statistic
Problem Description
给你一个由大写字母组成的组成的字符串,你可以用如下规则对其进行编码:
1、 包含K个相同字母的连续字符串可以用KX表示,其中X是相同的字母。
2、 如果K为1,不输出K
Input
输入有多组,直到文件结束。每组一个字符串,长度为10000以内
Output
输出编码后的字符串。
Example Input
ABCABBCCC
Example Output
ABCA2B3C
Hint
Author
lin
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char a[10500];
int k,i,s;
while(gets(a))
{
int len=strlen(a);
for(i=0; i<len; i++)
{
s=1;
for(k=i; k<len; k++)
{
if(a[k]==a[k+1])///AAAABBBB 先解决AAAA
{
s++;
i++;
}
else break;
}
if(s!=1) printf("%d",s);///明显是一个一个输出
printf("%c",a[i]);///解决一种以后,进行下一次循环
}
printf("\n");
}
return 0;
}
/**
示列:
AABBBAA
2A3B2A
思想:1.分而治之
#include <stdlib.h>
#include <string.h>
int main()
{
char a[10500];
int k,i,s;
while(gets(a))
{
int len=strlen(a);
for(i=0; i<len; i++)
{
s=1;
for(k=i; k<len; k++)
{
if(a[k]==a[k+1])///AAAABBBB 先解决AAAA
{
s++;
i++;
}
else break;
}
if(s!=1) printf("%d",s);///明显是一个一个输出
printf("%c",a[i]);///解决一种以后,进行下一次循环
}
printf("\n");
}
return 0;
}
/**
示列:
AABBBAA
2A3B2A
思想:1.分而治之
0 0
- 编码 分而治之
- 分而治之
- 分而治之
- 分而治之
- 分而治之算法
- 分而治之算法
- 解决之道:分而治之
- 分而治之策略
- 分而治之算法
- 2.分而治之
- 分而治之算法
- 算法中的分而治之思想
- J2ME中的分而治之
- 算法——分而治之
- 分而治之与步步为营
- 多进程与分而治之
- 统一考虑与分而治之
- “分而治之”是一种艺术
- openstack 逻辑构架真相
- A Serial Killer
- table元素的宽度/高度设置问题
- Makefile 中 -wl ,rpath 以及 O0 O1 O2 O3 Os 的用法
- 《精进:如何成为一个很厉害的人》
- 编码 分而治之
- 可重入函数与线程安全
- 第七讲项目三 算工资
- IOS缓存管理之PINCache使用
- eclipse设置默认编码格式utf-8
- beego框架简介
- 工作流学习——Activiti流程变量五步曲
- Epoll的使用详解
- [leetcode]187. Repeated DNA Sequences