码迷,mamicode.com
首页 > 其他好文 > 详细

1198.a+b(大整数加法)

时间:2018-10-01 19:06:19      阅读:181      评论:0      收藏:0      [点我收藏+]

标签:a+b   ++   scanf   str   加法   包括   大整数   size   ret   

题目描述:

实现一个加法器,使其能够输出a+b的值。

输入:

输入包括两个数a和b,其中a和b的位数不超过1000位。

输出:

可能有多组测试数据,对于每组数据,
输出a+b的值。

样例输入:
2 6
10000000000000000000 10000000000000000000000000000000
样例输出:
8
10000000000010000000000000000000
#include<stdio.h>
#include<string.h>
#include<algorithm>

struct biginteger{
    int digit[1000];
    int size;
    void init(){  //初始化 
        for(int i=0;i<1000;i++) digit[i]=0;
        size=0;
    }
    void set(char str[]){
        init();
        int L=strlen(str);
        for(int i=L-1,j=0,t=0,c=1;i>=0;i--){
            t+=(str[i]-0)*c;
            j++;
            c+=10;
            if(j==4 || i==0){
                digit[size++]=t;
                j=0;
                t=0;
                c=1;
            }
        }
    }
    void output(){
        for(int i=size-1;i>=0;i--){
            if(i!=size-1) printf("%04d",digit[i]);
            else printf("%d",digit[i]);
        }
        printf("\n");
    }
    biginteger operator + (const biginteger &A) const{
    biginteger ret;
    ret.init();
    int carry=0;
    for(int i=0;i<A.size || i<size;i++){
        int tmp=A.digit[i]+digit[i]+carry;
        carry=tmp/10000;
        tmp%=10000;
        ret.digit[ret.size++]=tmp;
    }
    if(carry!=0){
        ret.digit[ret.size++]=carry;
    }
    return ret;
    }
}a,b,c;

char str1[1002],str2[1002];

int main(){
    while(scanf("%s%s",str1,str2)!=EOF){
        a.set(str1);
        b.set(str2);
        c=a+b;
        c.output();
    }
    return 0;    
}

 

1198.a+b(大整数加法)

标签:a+b   ++   scanf   str   加法   包括   大整数   size   ret   

原文地址:https://www.cnblogs.com/bernieloveslife/p/9735263.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!