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; }
相关文章推荐
- 关于java I/O的杂谈
- 理解和正确使用Java中的断言(assert)
- java设计模式的3种形式
- 编译原理词法分析器(java)版的核心代码
- 03.SpringMVC 初始化 - FrameworkServlet
- Java_数组1_16.5.12
- Struts2读取配置文件的顺序
- maven常见开发配置spring,hibernate,structs,jdbc,log4j,mybatis
- Java中的抽象类与接口的特点和区别
- 三、jdk工具之jstack(Java Stack Trace)
- Java并发包Concurrent下Callable和Future实战
- [团队项目] Scrum 项目 3.0 SCRUM 流程的步骤2: Spring 计划
- Java中的继承
- java多线程-线程的实现
- Spring记录之Bean属性配置、依赖关系及生命周期
- java变量初始化
- Spring Mybatis整合
- java--继承
- 【JDK】:ArrayList和LinkedList源码解析
- Java_大数值_16.5.12