[题目描述]
斐波那契数列是指这样的数列:数列的第一个和第二个数都为 1,接下来每个数都等于前面 2个数之和。
给出一个正整数 a,要求斐波那契数列中第 a 个数是多少。
输入:
第 1 行是测试数据的组数 n,后面跟着 n 行输入。每组测试数据占 1 行,包括一个正整数 a(1≤a≤30)。
输出:
输出有 n 行,每行输出对应一个输入。输出应是一个正整数,为斐波那契数列中第 a 个数的大小。
样例输入1
4
5
2
19
1
样例输出1
5
1
4181
1
来源/分类(难度系数:一星)
完整代码展示:
a=int(input())
b=[]
for i in range(a):
c=int(input())
b.append(c)
for j in range(0,len(b)):
d=[1,1]
e=2
while e<b[j]:
d.append(d[-2]+d[-1])
e+=1
print(d[-1])
代码解释:
“a=int(input()) ”,让用户输入所需求的斐波那契数列的第几项的组数。
“b=[]
for i in range(a):
c=int(input())
b.append(c) ”,建立一个空列表b。让用户输入所需求的斐波那契数列的第几项,接着将其添加进b中,重复a次。
“for j in range(0,len(b)):
d=[1,1]
e=2
while e<b[j]:
d.append(d[-2]+d[-1])
e+=1
print(d[-1]) ”,依次遍历列表b中的所有元素,每循环一次,就建立一个列表d,并令d=[1,1](1,1是斐波那契数列的前两项),设置循环密码子为e(用来显示循环到斐波那契数列的第几项),将其初始值设为2。当e<b[j]时,列表d就添加一个新元素,该元素的值为其前面两项的值的和,每循环一次,e就加1,直至e=b[j](循环至所求项),循环中止,然后打印列表d的最后一项(所求项)。以此循环,直至依次遍历完列表b中所有元素。
运行效果展示: