题目:http://acm.hdu.edu.cn/showproblem.php?pid=1250

思路:本题的Fibonacci数列是扩展的四阶的Fibonacci数列,用递推关系式求解即可.

题目提示,所求的Fibonacci数最多2500位,所以不能用已有的数据类型表示,可以采用数组存储数字,模拟加法.

由于没有给F(n)的n最大为多少,所以需要估计一下.经过反复测试,F(7000)约为2000位左右,如果设置数组长度为2500+1,则计算得到F(7500)的结果沾满了2500+1位(),所以我们只需要计算到n=7500即可.

在写代码的时候设置一个数组a[7500][2500+1],则a[i][j]表示待求的F(i)的i的2500+1位中的第j位.

C++代码如下:

#include<iostream>
#include<string.h>
using namespace std; #define maxn 7500//最多算到
#define len 2500 + 1 //最多2500+1位
int a[maxn][len]; int main()
{
int i,j;
for(i=1;i<maxn;i++)//所有的a[i]的每一位初始化为0
memset(a[i],0,sizeof(a[i])); a[1][len-1] = a[2][len-1] = a[3][len-1] = a[4][len-1] = 1;//F(1)F(2)F(3)F(4)都为1 for(i=5;i<maxn;i++)//从5开始
{
int c = 0;
for(j=len-1;j>=0;j--)//计算F(i)
{
c += + a[i-1][j] + a[i-2][j] + a[i-3][j] + a[i-4][j] ;
a[i][j] = c % 10;
c = c / 10;
}
} int n;
while(cin>>n)
{
for(i=0;i<len;i++)
if(a[n][i])
break;//去掉前导0
for(j=i;j<len;j++)
cout << a[n][j];
cout << endl;
}
return 0;
}

上述代码,提交无法通过,显示MLE.

上述代码中a[i]的每一个元素仅存储一位数,可以用a[i]的每一个元素存多位数,例如存4位,则2500位需要625个元素存储.所以数组a可以定义为a[7500][625].如下图:

两种存储方式的每一位都是int型的,所以第二种更节省空间,也更节省时间.采用这种方式可以避免第一种存储方式所产生的TLE或者MLE.

C++代码如下:

#include<iostream>
#include<string.h>
using namespace std; #define maxn 7500
#define len 625 //每个元素可以存 4 位,一共要存2500位,一共需要 625个数组元素.
int a[maxn][len]; int main()
{
int i,j; for(i=1;i<maxn;i++)//一些初始化工作
memset(a[i],0,sizeof(a[i]));
a[1][len-1] = a[2][len-1] = a[3][len-1] = a[4][len-1] = 1; for(i=5;i<maxn;i++)//从5开始
{
int c = 0;
for(j=len-1;j>=0;j--)//计算F(i)
{
c += (a[i-1][j] + a[i-2][j] + a[i-3][j] + a[i-4][j]);
a[i][j] = c % 10000;//进位处理:不是10,不是1000,因为9999仍然是四位数,只有到了10000才能进位
c /= 10000;
}
} int n;
while(scanf("%d",&n)!=EOF)
{
if(n<=4)
printf("%s\n","1");
else
{
int i,j;
for(i=0;i<len;i++)
if(a[n][i])
break; printf("%d",a[n][i]);//先输出第一个[四位数],这样输入默认去掉前导0.
for(j=i+1;j<len;j++)//以后输入的中间0要保留.
printf("%04d",a[n][j]);//注意此处输出格式 "%04d".
printf("\n");
}
} return 0;
}

上述代码,提交可以通过.

小结:

1.由于每个元素存储4位,所以在输出的时候,除了首位的前面的0要去掉以外,后面的位的0必须保留.

例如:输出[0023][0208][1205][0001].

错误:printf("%d",a[n][j]);输出结果:2320812051

正确:先输出[0023],前面的00去掉,即:printf("%d",a[n[0]]);再输出后面,有前导0的要保留即:printf("%04d",a[n][j]);(j>=1)输出结果:23020812050001

2.采用【一个数组元素存储4位】相当于采用了10000进制,也可以采用【一个数组元素存储8位】的方法,相当于是100000000进制,那么在输出的时候也要用printf("%08d",a[n][j]);的方法.

参考:

http://blog.csdn.net/vsooda/article/details/7985496

http://blog.csdn.net/zwj1452267376/article/details/47132583

【hdoj_1250】Hat's Fibonacci(大数)的更多相关文章

  1. HDOJ/HDU 1250 Hat's Fibonacci(大数~斐波拉契)

    Problem Description A Fibonacci sequence is calculated by adding the previous two members the sequen ...

  2. Hat's Fibonacci(大数,好)

    Hat's Fibonacci Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  3. Hat's Fibonacci(大数加法+直接暴力)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1250 hdu1250: Hat's Fibonacci Time Limit: 2000/1000 M ...

  4. HDU 1250 Hat's Fibonacci(大数相加)

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1250 Hat's Fibonacci Time Limit: 2000/1000 MS (Java/Ot ...

  5. HDU 1250 Hat's Fibonacci (递推、大数加法、string)

    Hat's Fibonacci Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  6. hdu 1250 Hat's Fibonacci

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1250 Hat's Fibonacci Description A Fibonacci sequence ...

  7. HDUOJ----1250 Hat's Fibonacci

    Hat's Fibonacci Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  8. (二维数组 亿进制 或 滚动数组) Hat's Fibonacci hdu1250

    Hat's Fibonacci Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  9. hdu 1250 Hat's Fibonacci(java,简单,大数)

    题目 java做大数的题,真的是神器,来一道,秒一道~~~ import java.io.*; import java.util.*; import java.math.*; public class ...

随机推荐

  1. 【DP】【P5080】 Tweetuzki 爱序列

    Description Tweetuzki 有一个长度为 \(n\) 的序列 \(a_1~,~a_2~,~\dots~,a_n\). 他希望找出一个最大的 \(k\),满足在原序列中存在一些数 \(b ...

  2. Tensorflow BatchNormalization详解:4_使用tf.nn.batch_normalization函数实现Batch Normalization操作

    使用tf.nn.batch_normalization函数实现Batch Normalization操作 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 吴恩达deeplearnin ...

  3. python---爬虫相关性能(各个异步模块的使用,和自定义异步IO模块)

    一:线程池,进程池等相关文章了解 python---基础知识回顾(十)进程和线程(py2中自定义线程池和py3中的线程池使用) python---基础知识回顾(十)进程和线程(协程gevent:线程在 ...

  4. 海思HI35XX之----视频处理单元各通道间的关系

    最近在折腾HI3518C的芯片,应用到IPCamera上,最终获取多路不同分辨率的视频流供不同需求的预览切换.此处简单记录一下视频前处理元VPSS(Video Process Sub-System)的 ...

  5. CSS常用标签-手打抄录-感谢原未知博主-拜谢了

    CSS常用标签   CSS常用标签 一 CSS文字属性 color : #999999; /*文字颜色*/ font-family : 宋体,sans-serif; /*文字字体*/ font-siz ...

  6. Oracl闪回数据命令。

    当数据库操作没有备份,并且误删数据.可闪回任何 当前闪回15分钟前数据库状态.  alter table BASE_APPOINT_LOG enable row movement;flashback  ...

  7. 2017 国庆湖南Day2

    期望得分:100+30+100=230 实际得分:100+30+70=200 T3 数组开小了 ..... 记录 1的前缀和,0的后缀和 枚举第一个1的出现位置 #include<cstdio& ...

  8. bzoj 2820 / SPOJ PGCD 莫比乌斯反演

    那啥bzoj2818也是一样的,突然想起来好像拿来当周赛的练习题过,用欧拉函数写掉的. 求$(i,j)=prime$对数 \begin{eqnarray*}\sum_{i=1}^{n}\sum_{j= ...

  9. Linux type命令的用法

    一般情况下,type命令被用于判断另外一个命令是否是内置命令,但是它实际上有更多的用法. 1.判断一个名字当前是否是alias.keyword.function.builtin.file或者什么都不是 ...

  10. 巧妙利用JQuery和Servlet来实现跨域请求

    在网上看到很多的JQuery跨域请求的文章,比较有意思.这里我发表一个Servlet与JQuery配置实现跨域的代码,供大家参考.不足之处请指教 原理:JavaScript的Ajax不可以跨域,但是可 ...