题目描述
斐波那契数列是指这样的数列:数列的第一个和第二个数都为 1,接下来每个数都等于前面 2 个数之和。
给出一个正整数 a,要求斐波那契数列中第 a 个数是多少。
输入格式
第 11 行是测试数据的组数 n,后面跟着 n 行输入。每组测试数据占 1行,包括一个正整数 a(1≤a≤30)。
输出格式
输出有 n 行,每行输出对应一个输入。输出应是一个正整数,为斐波那契数列中第 a 个数的大小。
输入输出样例
输入 #1
4 5 2 19 1
输出 #1
1 4181 1
看代码
#include<bits/stdc++.h>
using namespace std;
int n;
int main(){
cin>>n;
for(int i=1;i<=n;i++){
int a;
cin>>a;
int x[40];
x[1]=x[2]=1;
for(int i=3;i<=a;i++)
x[i]=x[i-1]+x[i-2];
cout<<x[a]<<endl;
}
return 0;
}
这题其实就是循环的应用,除了前两个数已经被赋予了值,其它每个数都是前两个数相加的和,注意初始化。这里有多组数据,所以应该再加一重循环。如果你使用递归的话,时间复杂度会较之更高,所以循环更好。