蓝桥杯_基础练习_FJ的字符串
问题
问题描述
FJ在沙盘上写了这样一些字符串:
A1 = “A”
A2 = “ABA”
A3 = “ABACABA”
A4 = “ABACABADABACABA”
… …
你能找出其中的规律并写所有的数列AN吗?
输入格式
仅有一个数:N ≤ 26。
输出格式
请输出相应的字符串AN,以一个换行符结束。输出中不得含有多余的空格或换行、回车符。
样例
-
输入
3 -
输出
ABACABA
问题解决
主要思路
- 首先我们可以看出这些字符串是两边对称的。
- 看上去是不是很像
中序遍历的结果。(好吧 感觉很像有点牵强,但这样可以做到)。
代码
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
int n = scanner.nextInt();
vis(n);
}
//通过中序遍历的方式来输出这个字符串
private static void vis(int n) {
// TODO Auto-generated method stub
if (n>0) {
if (n==1) {
System.out.print('A');
}else {
vis(n-1);
System.out.print((char)('A'+n-1));
vis(n-1);
}
}
}
}
本文介绍蓝桥杯基础练习中FJ的字符串题目,解析了字符串生成的规律,并提供了一种基于中序遍历的Java实现方法,帮助读者理解和解决此类递归字符串生成问题。
690

被折叠的 条评论
为什么被折叠?



