0
点赞
收藏
分享

微信扫一扫

蓝桥杯 基础练习 FJ的字符串(递归)

问题描述

  FJ在沙盘上写了这样一些字符串:
  A1 = “A”
  A2 = “ABA”
  A3 = “ABACABA”
  A4 = “ABACABADABACABA”
  … …
  你能找出其中的规律并写所有的数列AN吗?

输入格式

 仅有一个数:N ≤ 26。

输出格式

 请输出相应的字符串AN,以一个换行符结束。输出中不得含有多余的空格或换行、回车符。

解题思路

     观察这个字符串的规律,Ai字符串长度为2^i-1,且左右两边对称,所以可以写两个递归,让左右两边一样。

#include<iostream>
using namespace std;
#include<string>
void f(int n)
{
	if (n == 1) cout << "A";
	else
	{
		f(n - 1);
		char s = 'A' + n - 1;
		cout << s;
		f(n - 1);
	}
}
int main()
{
	int N;
	cin >> N;
	f(N);
	return 0;
}
举报

相关推荐

0 条评论