题目描述
从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
import java.util.Scanner; public class 奇怪的数列 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String s = sc.nextLine(); int n = Integer.parseInt(sc.nextLine()); for (int i=0;i<n;i++) s = f(s); System.out.println(s); } public static String f(String x){ String y=""; char t = x.charAt(0);//t:用于存储字符串 x 的第一个字符。 int n = 1; for (int i=1;i<x.length();i++){ char c = x.charAt(i); if(c==t) n++; else { y+=n;//空字符串可以直接写东西进去 y+=t; t=c; n=1; } } y+=n; y+=t; return y; } }
问题
(1) 如何获取字符串的第一个字符,并且可以循环依次往下获取
第一种:把字符串变为数组
int a[] = new int[str.length()]; for (int i=0;i<str.length();i++){ a[i] = Integer.parseInt(str.substring(i,i+1)); //str.substring(i,i+1)==获取字符串的第一个字符,并且可以循环依次往下获取 }
第二种:直接取出字符串,拿出第一个字符,依次比较
注:(1)一个空字符串可以直接写进东西;y+=n
(2)提取字符串第几个字符用 chatAt(i)