Fork me on GitHub

大整数加法

写程序求两个相同位数的大整数之和

输入

两个大整数(位数不超过1000)

输出

两个大整数的和

样例输入

1234567890 1234567890
111111111111 222222222222

样例输出

2469135780
333333333333
#include <stdio.h>
#include <string.h>
char add(char a, int &tag){
int r = a-'0'+tag;
if (r <= 9){
   tag = 0;
   return r+'0';
}
else{
   tag = 1;
   return r+38;
}
}
char add(char a, char b, int &tag){
int r = a+b-96+tag;
if (r <= 9){
   tag = 0;
   return r+'0';
}
else{
   tag = 1;
   return r+38;
}
}
int add(char sum[], char a[], char b[]){
int i = strlen(a)-1, j = strlen(b)-1, k = 0, tag = 0;
while (i>=0 && j>=0){
   sum[k++] = add(a[i--], b[j--], tag);
}
while (i >= 0){
   sum[k++] = add(a[i--], tag);
}
while (j >= 0){
   sum[k++] = add(b[j--], tag);
}
if (tag != 0){
   sum[k++] = tag+'0';
}
return k;
}
int main(){
char a[1001], b[1001], sum[1002];
int i, k;
while (scanf("%s %s", a, b) == 2){
   k = add(sum, a, b);
   for (i=k-1; i>=0; --i){
    printf("%c", sum[i]);
   }
   printf("\n");
}
return 0;
}

 

posted @ 2018-10-23 18:14  Lazy.Cat  阅读(376)  评论(0编辑  收藏  举报