标题:奇怪的数列
从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,否则按无效代码处理。
这是代码1:
import java.util.Scanner;
public class Demo {
private static int k, p;
private static char[] s1 = new char[10000];
private static int[] s2 = new int[10000];
public static void main(String[] args) {
// TODO 自动生成的方法存根
Scanner sc = new Scanner(System.in);
String n = sc.nextLine();
int m = sc.nextInt();
char[] ch = n.toCharArray();
for (int i = 0; i < ch.length; i++) {
s1[i] = ch[i];
}
p = ch.length;
while (m > 0) {
k = 0;
for (int i = 0; i < p;) {
int t = s1[i] - '0';
strNode m1 = duang(i);
i = m1.p;
s2[k++] = m1.sum;
s2[k++] = t;
}
p = k;
for (int j = 0; j < k; j++) {
s1[j] = (char) (s2[j] + '0');
}
m--;
}
for (int i = 0; i < k; i++) {
System.out.print(s2[i]);
}
}
public static strNode duang(int start) {
strNode mode = new strNode();
int sum = 1;
int i;
for (i = start; s1[i] == s1[i + 1]; i++) {
sum++;
}
mode.sum = sum;
mode.p = i + 1;
return mode;
}
}
class strNode {
int sum;
int p;
}
代码2:
import java.util.Scanner;
public class Main {
static String ts = "";
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
int n = sc.nextInt();
fn(str, n);
System.out.println(ts);
}
private static void fn(String str, int n) {
// TODO Auto-generated method stub
if (n <=0) {
ts = str;
return;
}
int lnum = 1;
String ss = "";
char cl;
char[] cs = str.toCharArray();
for (int i = 0; i < cs.length; i++) {
cl = cs[i];
if (i + 1 != cs.length) {
if (cl == cs[i + 1]) {
lnum++;
} else {
ss = ss +lnum + cl;//接下来三行顺序不能乱
cl = cs[i];
lnum = 1;
}
} else {
ss = ss + lnum + cl;
}
}
fn(ss, --n);
}
}