刚接触python,最近在做蓝桥杯题目,随手将自己当时最直接最暴力的第一想法记录分享一下,哈哈哈。
问题描述
FJ在沙盘上写了这样一些字符串:
A1 = “A”
A2 = “ABA”
A3 = “ABACABA”
A4 = “ABACABADABACABA”
… …
你能找出其中的规律并写所有的数列AN吗?
输入格式
仅有一个数:N ≤ 26。
输出格式
请输出相应的字符串AN,以一个换行符结束。输出中不得含有多余的空格或换行、回车符。
样例输入
3
样例输出
ABACABA
我的思路:
观察字符串我们发现字符串呈现出从新增加的字母处对称的关系,1到26对应26字母,AN在A(N-1)的基础上增加了N对应的字母,然后再拼接上A(N-1),如:A2=(A1)B(A1) ; A3=(A2)C(A2).;A4=…。
方法:
建立数字和字母一一对应的字典;建立列表,将所有的结果计算出来放入列表;使用枚举函数
遍历字典;将与输入n相等的索引的值打印。
n = int(input())
zm = {2:'B',3:'C',4:'D',5:'E',6:'F',7:'G',8:'H',
9:'I',10:'J',11:'K',12:'L',13:'M',14:'N',
15:'O',16:'P',17:'Q',18:'R',19:'S',20:'T',
21:'U',22:'V',23:'W',24:'X',25:'Y',26:'Z'}
ls = ['A']
start = 'A'
for j,value in zm.items():
start = start + str(value) + start ##字符串拼接
ls.append(start)
for i ,j in enumerate(ls,1): ##索引由1开始
if n == i:
print(j)
break
测试用例:
提交测似: