码迷,mamicode.com
首页 > 其他好文 > 详细

蓝桥杯历届-奇怪的数列

时间:2016-05-12 14:57:43      阅读:585      评论:0      收藏:0      [点我收藏+]

标签:

蓝桥杯历届-奇怪的数列


还不复习算法,估计国赛会跪。。。


标题:奇怪的数列

从X星截获一份电码,是一些数字,如下:
13
1113
3113
132113
1113122113
....

YY博士经彻夜研究,发现了规律:
第一行的数字随便是什么,以后每一行都是对上一行“读出来”
比如第2行,是对第1行的描述,意思是:1113,所以是:11133行,意思是:31,13,所以是: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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!