您的位置:首页 > 其它

蓝桥杯之奇怪的数列

2017-05-07 20:55 148 查看
题目:

从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 第六届;

import java.util.Scanner;

public class Exe72 {

public static void main(String[] args) {
Scanner  scanner = new Scanner(System.in);
int num = scanner.nextInt();
int time = scanner.nextInt();
dfs(num+"",0,time);
}

private static void dfs(String str, int count, int time) {
if (c
4000
ount >= time) {
System.out.println(str);
return ;
}
StringBuffer   sb = new StringBuffer();
int  ci = 1 ;
for (int i = 0; i < str.length()-1; i++) {
if (str.charAt(i)!=str.charAt(i+1)) {
sb.append(ci+""+str.charAt(i));
ci = 1;
}
else {
ci++;
}
}
sb.append(ci+""+str.charAt(str.length()-1));
dfs(sb.toString(),count+1,time);
}

}


打赏一点钱,帮我买杯咖啡,继续创作,谢谢大家!

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息