acm-高精度-大数相加

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
char a[5005],b[5005];
int aa[5005],bb[5005],sum[5006];
void f(char x[],int xx[])
{
    int lx=strlen(x);
    for(int i=0;i<lx;i++)
        xx[lx-i-1]=x[i]-'0';
}
int main()
{
    int t;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%s%s",a,b);
        memset(aa,0,sizeof(aa));
        memset(bb,0,sizeof(bb));
        memset(sum,0,sizeof(sum));
        f(a,aa);
        f(b,bb);
        int c=0,l;
        l=max(strlen(a),strlen(b));
        for(int i=0;i<=l;i++)
        {
            int d=aa[i]+bb[i]+c;
            sum[i]=d%10;
            c=d/10;
        }
        /*消除前缀0*/
        int e;
        for(e=5001;e>=0;e--)
        if(sum[e]!=0)break;
        for(int i=e;i>=0;i--)
        printf("%d",sum[i]);
        printf("\n");
    }
    return 0;
}


猜你喜欢

转载自blog.csdn.net/xqx1343002589/article/details/80694385