斐波那契数列(大数加法)

Posted Neord

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了斐波那契数列(大数加法)相关的知识,希望对你有一定的参考价值。

题意:

求斐波那契的前10000项目

分析:

模拟竖式加法, 用string作为数字的储存形式

#include<bits/stdc++.h>
using namespace std;
string add1(string s1, string s2)
{
    if (s1 == "" && s2 == "")   return "0";
    if (s1 == "")   return s2;
    if (s2 == "")   return s1;
    string maxx = s1, minn = s2;
    if (s1.length() < s2.length()){
        maxx = s2;
        minn = s1;
    }
    int a = maxx.length() - 1, b = minn.length() - 1;
    for (int i = b; i >= 0; --i){
        maxx[a--] += minn[i] - 0; //  a一直在减 , 额外还要减个‘0‘
    }
    for (int i = maxx.length()-1; i > 0;--i){
        if (maxx[i] > 9){
            maxx[i] -= 10;//注意这个是减10
            maxx[i - 1]++;
        }
    }
    if (maxx[0] > 9){
        maxx[0] -= 10;
        maxx = 1 + maxx;
    }
    return maxx;
}
int main(){
    string a[10007];
    a[3] = "4" , a[4] = "7";
    for(int i = 5; i <= 10000; i++){
        a[i] = add1(a[i-1],a[i-2]);
    }
    int n;
    while(cin >> n){
        cout << a[n] << "\n";
    }
}

 

以上是关于斐波那契数列(大数加法)的主要内容,如果未能解决你的问题,请参考以下文章

HDU1250大数+斐波那契数列

百度之星 预赛002 大数问题+斐波那契数列

HDU 1316 (斐波那契数列,大数相加,大数比较大小)

ACM_无聊者序列(斐波那契数列大数+同余+规律)

对斐波那契数列的理解

LeetCode面试题10-1. 斐波那契数列