杭电 1568 NYOJ 461 Fibonacci

原创 2012年03月23日 21:30:22

   题目让求Fibonacci数列的高四项,我们可知,一个数的n次方,若n=2.5,则其大小决定于n的整数部分即2,其小数点位置决定于n的小数部分即0.5。同理,Fibonacci数列也是这样,根据Fibonacci数列的通项公式,再转化为对数,就可以转化为上述问题。。题目:

又见Fibonacci数列

时间限制:1000 ms  |  内存限制:65535 KB
难度:4
描述
 数学神童小明终于把0到100000000的Fibonacci数列(f[0]=0,f[1]=1;f[i] = f[i-1]+f[i-2](i>=2))的值全部给背了下来。
接下来,CodeStar决定要考考他,于是每问他一个数字,他就要把答案说出来,不过有的数字太长了。所以规定超过4位的只要说出前4位(高4位)就可以了,可是CodeStar自己又记不住。于是他决定编写一个程序来测验小明说的是否正确。
输入
输入若干数字n(0 <= n <= 100000000),每个数字一行。读到文件尾结束。
输出
输出f[n]的前4个数字(若不足4个数字,就全部输出)。
样例输入
0
1
2
3
4
5
35
36
37
38
39
40
样例输出
0
1
1
2
3
5
9227
1493
2415
3908
6324
1023
ac代码:

#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
int f[24];
void init(){
  f[0]=0;f[1]=1;
  for(int i=2;i<=23;++i)
	  f[i]=f[i-1]+f[i-2];
}
int main(){
   init();
   int n;
   while(~scanf("%d",&n)){
     if(n<=20)
		 printf("%d\n",f[n]);
	 else{
	   double x=sqrt(5*1.0); double y=log10(1/x);
	   double z=n*log10(((x+1)/2));double p=y+z;
	   double q=p-(int)p;double xx=pow(double(10),q);
	   for(int i=1;;++i){
	     xx*=10;
		 if(xx>10000)
			 break;
	   }
	   printf("%d\n",((int)xx)/10);
	 }
   }
  return 0;
}


HDU-1568 Fibonacci

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1568 解题思路: 一遇到数学题就悲剧!! 我了个去啊!!!啥时候才能用公式瞬秒数学题啊。。。每次...
  • niushuai666
  • niushuai666
  • 2011年11月25日 21:42
  • 3227

HDU 1568 Fibonacci(斐波那契前四位)

HDU 1568 Fibonacci(矩阵快速幂+二分等比序列求和) tags: ACM 题目地址:HDU 1568 Fibonacci 题意:  中文题。 分析:  用取...
  • hcbbt
  • hcbbt
  • 2014年08月05日 01:15
  • 1417

**【杭电1568】Fibonacci

Fibonacci Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Stat...
  • idealistic
  • idealistic
  • 2016年11月12日 17:21
  • 114

NYOJ 461 又见Fibonacci数列

原题链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=461 这个题一看貌似和以前的斐波那契数列一样  就是数据可能大些。。。于是就认为...
  • PIAOYI0208
  • PIAOYI0208
  • 2012年03月06日 20:49
  • 621

nyoj 461 Fibonacci数列(四)

Fibonacci数列是个神奇的数列,它包含了太多的知识,有些你甚至想都想不到…… 这个题目的意思很简单了,但是这个题目绝对不是让你循环算出的,或许你做过fibonacci数列(二)的话,你也许...
  • H_R_D_127
  • H_R_D_127
  • 2012年03月27日 20:36
  • 578

【杭电oj】1568 - Fibonacci(数学)

Fibonacci Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...
  • wyg1997
  • wyg1997
  • 2016年04月09日 17:04
  • 470

杭电水体--Fibonacci Again 1021

题目大意是,给了你一个新的类似于斐波那契的递推式,问你第n个数是不是3的倍数。 这种题目不外乎2种方法: 1 找规律 2 数论 先看看找规律行不行,因为这是最简单。 7 11 18 29...
  • xueerfei008
  • xueerfei008
  • 2013年06月01日 13:47
  • 1430

hdu 1588 Gauss Fibonacci (矩阵)

Gauss Fibonacci Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)...
  • clover_hxy
  • clover_hxy
  • 2016年05月22日 20:09
  • 259

hdu 1588 Gauss Fibonacci 矩阵

#include #include #include #include #include using namespace std; #define LL long long LL maxn;...
  • a601025382s
  • a601025382s
  • 2013年08月21日 14:55
  • 711

杭电ACM1568——Fibonacci

巧用数学公式,两边去对数来算。 #include #include using namespace std; int main() { int n; int fib[21] = {0, 1...
  • qq_25425023
  • qq_25425023
  • 2015年11月19日 15:41
  • 369
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:杭电 1568 NYOJ 461 Fibonacci
举报原因:
原因补充:

(最多只允许输入30个字)