求斐波那契數列第1000項


#include <cstdio>

#include <cmath>
#include <iostream>
using namespace std;

const int maxn=1000+5;
long long fib[maxn]={1, 1};

void fibonacci(int n)
{
    for(int i=2;i<=n;i++)
    {
        fib[i] = fib[i-1] + fib[i-2];
        cout<<i<<endl;
        cout<<fib[i]<<endl;
        if(fib[i]<0) break;
    }
}

int main()
{
    //預處理生成
    fibonacci(1000);
    int n=0;
    while(scanf("%d", &n)==1)
    {
        printf("%lld\n", fib[n-1]);
    }

    return 0;
}

輸出:

91
7540113804746346429
92
-6246583658587674878

92項就溢出了,要采用高精度算法。



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM