生活随笔
收集整理的這篇文章主要介紹了
两个大数字相加
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
參照HPUOJ1163題:
?
題目描述
給定兩個整數(shù)A和B,讓你求出A+B的值。
輸入
第一行輸入一個整數(shù)T,代表有T組測試數(shù)據(jù)。
每組數(shù)據(jù)占兩行,第一行輸入一個整數(shù)A,第二行輸入一個整數(shù)B。
注:1<=T<=30,1<=A,B<=10666666。
輸出
對每組數(shù)據(jù),輸出A+B的最后結(jié)果。?
樣例輸入
1
233333333333333333333333333333333333333
666666666666666666666666666666666666666
樣例輸出
899999999999999999999999999999999999999
代碼:
?
#include <iostream>#include <cstring> using namespace std;char a[1000000];char b[1000000];int c[1000000],d[1000000],e[1000000];int main(){int i,k,j,q,w,r;cin>>r;while(r--){memset(c,0,sizeof(c));memset(d,0,sizeof(d));memset(e,0,sizeof(e));cin>>a>>b;j=0;q=strlen(a);w=strlen(b);k=q>w?q:w;for(i=q-1;i>=0;i--){c[j]=a[i]-'0';j++;}j=0;for(i=w-1;i>=0;i--){d[j]=b[i]-'0';j++;}for(i=0;i<k;i++)e[i]=c[i]+d[i]; for(i=0;i<k;i++){if(e[i]>9){e[i]-=10;e[i+1]++;}}for(i=k;i>=0;i--){if(i==k && e[k]==0) continue;cout<<e[i];}cout<<endl;} return 0;}
?
總結(jié)
以上是生活随笔為你收集整理的两个大数字相加的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。