大菲波数
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 16837 Accepted Submission(s): 5567
Problem Description
Fibonacci数列,定义如下:
f(1)=f(2)=1
f(n)=f(n-1)+f(n-2) n>=3。
计算第n项Fibonacci数值。
f(1)=f(2)=1
f(n)=f(n-1)+f(n-2) n>=3。
计算第n项Fibonacci数值。
Input
输入第一行为一个整数N,接下来N行为整数Pi(1<=Pi<=1000)。
Output
输出为N行,每行为对应的f(Pi)。
Sample Input
5 1 2 3 4 5
Sample Output
1 1 2 3 5
Source
还是大数,不解释,用Java
AC代码:
import java.math.BigDecimal;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
BigDecimal a[]=new BigDecimal[1005];
a[1] = a[2] = new BigDecimal(1);
for (int i = 3; i <= 1000;i++) {
a[i] = a[i-1].add(a[i-2]);
}
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
while(n-->0){
int x = sc.nextInt();
System.out.println(a[x]);
}
}
}
AC代码2:
#include <stdio.h>
#include <string.h>
#define max 1005
int a[max][max];
int main()
{
int t,n,i,j;
memset(a,0,sizeof(a));
a[1][1]=1;//二维数组,高维表示项数,低维表示长度
a[2][1]=1;
int sum;
int carry=0;
for(i=1; i<max-2; i++)
{
for(j=1; j<max; j++)
{
sum=a[i][j]+a[i+1][j]+carry;
a[i+2][j]=sum%10;
carry=sum/10;
}
}
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(i=max; i>0; i--)
{
if(a[n][i])
{
break;
}
}
for(; i>0; i--)
{
printf("%d",a[n][i]);
}
printf("\n");
}
return 0;
}