题目描述
报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一个数。其前五项如下:
-
1
-
11
-
21
-
1211
-
111221
1 被读作 “one 1” (“一个一”) , 即 11。
11 被读作 “two 1s” (“两个一”), 即 21。
21 被读作 “one 2”, “one 1” (“一个二” , “一个一”) , 即 1211。
给定一个正整数 n(1 ≤ n ≤ 30),输出报数序列的第 n 项。
注意:整数顺序将表示为一个字符串。
思路
这个题需要用到递归的方法,因为每次都需要用到上一个整数序列。
题目的用意是输出连续的数字的数量以及该数字。
代码
public class Counting {
public String countAndSay(int n) {
if(n == 1)
return "1";
String str = countAndSay(n-1) + "*";
char[] c = str.toCharArray();
int count = 1;
StringBuilder s = new StringBuilder();
for(int i = 0; i < c.length - 1; i++)
{
if(c[i] == c[i + 1])
{
count++;
}
else
{
s.append("" + count + c[i]);
count = 1;
}
}
return s.toString();
}
}