80分求助!!!

P1255 数楼梯

Sunshine_su @ 2024-01-28 16:08:36

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int a[10010],b[10010],c[10010];
void s2BIG(string s,int a[])
{
    int l=s.size();
    a[0]=l;
    for(int i=1;i<=l;i++) a[i]=s[l-i]-'0';
}
void addBIG(int a[],int b[],int c[])
{
    c[0]=max(a[0],b[0]);
    int t=0;
    for(int i=1;i<=c[0];i++)
    {
        if(i<=a[0]) t+=a[i];
        if(i<=b[0]) t+=b[i];
        c[i]=t%10;
        t/=10;
    }
    if(t>0) c[0]++,c[c[0]]=t;
}
void printBIG(int a[])
{
    int l=a[0];
    for(int i=l;i>=1;i--) cout<<a[i];
}
void copy(int a[],int b[]){for(int i=0;i<=b[0];i++) a[i]=b[i];}
int main() {
    int n;
    cin>>n;
    if(n==0) cout<<0; 
    s2BIG("1",a);
    s2BIG("2",b);
    for(int i=3;i<=n;i++)
    {
        addBIG(a,b,c);
        copy(a,b);
        copy(b,c);
    }
    printBIG(c);
    return 0;
}

by _coastline_ @ 2024-01-28 16:24:32

um您是不是忘记处理了N=1或2的情况(?


by __PRO__ @ 2024-01-28 16:29:43

@Sunshine_su

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int a[10010],b[10010],c[10010];
void s2BIG(string s,int a[])
{
    int l=s.size();
    a[0]=l;
    for(int i=1;i<=l;i++) a[i]=s[l-i]-'0';
}
void addBIG(int a[],int b[],int c[])
{
    c[0]=max(a[0],b[0]);
    int t=0;
    for(int i=1;i<=c[0];i++)
    {
        if(i<=a[0]) t+=a[i];
        if(i<=b[0]) t+=b[i];
        c[i]=t%10;
        t/=10;
    }
    if(t>0) c[0]++,c[c[0]]=t;
}
void printBIG(int a[])
{
    int l=a[0];
    for(int i=l;i>=1;i--) cout<<a[i];
}
void copy(int a[],int b[]){for(int i=0;i<=b[0];i++) a[i]=b[i];}
int main() {
    int n;
    cin>>n;
    s2BIG("1",a);
    s2BIG("1",b);
    for(int i=2;i<=n;i++)
    {
        addBIG(a,b,c);
        copy(a,b);
        copy(b,c);
    }
    printBIG(b);
    return 0;
}

by Sunshine_su @ 2024-01-28 22:01:52

已过,谢谢!


|