博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
杭电 1568 NYOJ 461 Fibonacci
阅读量:5010 次
发布时间:2019-06-12

本文共 1146 字,大约阅读时间需要 3 分钟。

   题目让求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个数字,就全部输出)。
样例输入
012345353637383940
样例输出
011235922714932415390863241023
ac代码:

#include 
#include
#include
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;}

转载于:https://www.cnblogs.com/javaspring/archive/2012/03/23/2656391.html

你可能感兴趣的文章
跨浏览器问题的五种解决方案
查看>>
XPath定位时,使用文本的方法小技巧。
查看>>
安装pandas报错(AttributeError: 'module' object has no attribute 'main')
查看>>
ch02 fundamental definition 01
查看>>
JSON解析
查看>>
Position is everything?(css定位学习的一些心得)(一)
查看>>
如何提高编程水平
查看>>
Jquery Uploadify3.21.与2.1版本 使用中存在的问题--记录三
查看>>
Linux查看进程的内存占用情况 分类: ubuntu ...
查看>>
[BZOJ 2818]Gcd
查看>>
FORM值传递与地址传递
查看>>
(译)yaml快速教程
查看>>
C:大数相加
查看>>
160. Intersection of Two Linked Lists
查看>>
人生苦短,我用python-- Day11
查看>>
JAVA Bean
查看>>
ehcache memcache redis 三大缓存男高音_转
查看>>
curd_3
查看>>
百度地图API示例之设置地图显示范围
查看>>
Java构造方法、重载及垃圾回收
查看>>