加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

用大数加法实现斐波那契数列

发布时间:2020-12-14 05:11:05 所属栏目:大数据 来源:网络整理
导读:E - Edge Case ? F[3]=4; F[4]=7; F[5]=11; 依次类推,求[3,2000]的斐波那契数 ? ? #includeiostream #include algorithm #include string #include string .h #include math.h using namespace std; int n; int F[ 10001 ][ 2500 ]; int main(){ memset(F,

E - Edge Case

?

F[3]=4;

F[4]=7;

F[5]=11;

依次类推,求[3,2000]的斐波那契数

?

?

#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
#include<math.h>
using namespace std;
int n;
int F[10001][2500];
 
int main()
{
    memset(F,0,sizeof(F));
    F[3][1] = 4,F[3][0] = 1;//F[i][0]表示的是第i个斐波那契数的长度
    F[4][1] = 7,F[4][0] = 1;
    for (int i = 5; i <= 10000; i++)
    {
        int in = 0;//进位
        int j;
        for (j = 1; j <= F[i - 1][0]; j++)
        {
            F[i][j] = F[i - 1][j] + F[i - 2][j] + in;
            in = F[i][j] / 10;
            F[i][j] = F[i][j] % 10;
            F[i][0]++;
        }
        if (in)
        {
            F[i][j] = in;
            F[i][0]++;
        }
    }
    while (cin >> n)
    {
        for (int j = F[n][0]; j >= 1; j--)
            cout << F[n][j];
        cout << endl;
    }
    return 0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读