大数的加法
发布时间:2020-12-14 02:54:34 所属栏目:大数据 来源:网络整理
导读:输入两个很大的数字(这两个数字不能以数字的形式存进计算机)并对他们求和; #include "stdio.h"#include "string.h"int main(){char a[10000],b[10000];int result[20000];int i,j,k;i=0;while((a[i++]=getchar())!='n');a[i-1]=' ';i=0;while((b[i++]=g
输入两个很大的数字(这两个数字不能以数字的形式存进计算机)并对他们求和; #include "stdio.h" #include "string.h" int main() { char a[10000],b[10000]; int result[20000]; int i,j,k; i=0; while((a[i++]=getchar())!='n'); a[i-1]=' '; i=0; while((b[i++]=getchar())!='n'); b[i-1]=' '; for(i=0;i<200;i++) result[i]=0; for(i=strlen(a)-1,j=strlen(b)-1,k=0;i>=0 && j>=0;i--,j--,k++) { if((a[i]-'0')+(b[j]-'0')+result[k]>9) result[k+1]=result[k+1]+1; result[k]=((a[i]-'0')+(b[j]-'0')+(result[k]))%10; } if(i<0) { for(;j>=0;j--,k++) { if(((b[j]-'0')+result[k])>9) result[k+1]=1; result[k]=((b[j]-'0')+result[k])%10; } } if(j<0) { for(;i>=0;i--,k++) { if(((a[i]-'0')+result[k])>9) result[k+1]=1; result[k]=((a[i]-'0')+result[k])%10; } } if(result[k]!=0) { result[k+1]=' '; for(i=k;i>=0;i--) printf("%d",result[i]); } else { result[k]=' '; for(i=k-1;i>=0;i--) printf("%d",result[i]); } putchar('n'); return 0; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |