您的位置:首页 > 编程语言 > Java开发

HDU 1715 大菲波数 (Java大法好,C模拟也不要错过)

2016-05-12 22:21 603 查看


大菲波数

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数值。

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

2007省赛集训队练习赛(2)

原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1715

还是大数,不解释,用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
[i])
{
break;
}
}
for(; i>0; i--)
{
printf("%d",a
[i]);
}
printf("\n");
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: