标签:
还不复习算法,估计国赛会跪。。。
标题:奇怪的数列
从X星截获一份电码,是一些数字,如下:
13
1113
3113
132113
1113122113
....
YY博士经彻夜研究,发现了规律:
第一行的数字随便是什么,以后每一行都是对上一行“读出来”
比如第2行,是对第1行的描述,意思是:1个1,1个3,所以是:1113
第3行,意思是:3个1,1个3,所以是:3113
请你编写一个程序,可以从初始数字开始,连续进行这样的变换。
数据格式:
第一行输入一个数字组成的串,不超过100位
第二行,一个数字n,表示需要你连续变换多少次,n不超过20
输出一个串,表示最后一次变换完的结果。
例如:
用户输出:
5
7
则程序应该输出:
13211321322115
资源约定:
峰值内存消耗(含虚拟机) < 512M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
这是国赛第四题,也就是编程大题第一道,不是很难。。水过:
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
struct mode {
int sum, p;
};
int N, M, s2[10000];
char s1[10000];
mode getMode(int start) {
mode m1;
int i, sum = 1;
for (i = start; s1[i] == s1[i+1]; i++) {
sum++;
}
m1.sum = sum;
m1.p = i+1;
return m1;
}
int main() {
freopen("in.txt", "r", stdin);
scanf("%d%d", &N, &M);
int k = 0;
sprintf(s1, "%d", N);
while(M--) {
int len = strlen(s1);
k = 0;
for (int i = 0; i < len;) {
int t = s1[i]-‘0‘;
mode m1 = getMode(i);
i = m1.p;
s2[k++] = m1.sum;
s2[k++] = t;
}
memset(s1, 0, sizeof(s1));
for (int i = 0; i < k; i++) s1[i] = s2[i]+‘0‘;
}
for (int j = 0; j < k; j++) printf("%d", s2[j]);
return 0;
}
标签:
原文地址:http://blog.csdn.net/acm_th/article/details/51361790