高精度加法

#include<iostream>
#include<vector>
using namespace std;

vector<int> add(vector<int> &A,vector<int> &B){
    vector<int> C;

    if(A.size()<B.size()) return add(B,A);

    int t = 0;  //用t表示进位
    for(int i = 0;i<A.size();i++){
        t += A[i];
        if(i<B.size()) t += B[i];
        C.push_back(t%10);
        t = t/10;
    }

    if(t) C.push_back(t);

    return C;
}


int main(){
    string a,b;
    cin>>a>>b;
    vector<int> A;
    vector<int> B;
    vector<int> C;   
    for(int i = a.size()-1;i>=0;i--) A.push_back(a[i]-'0');
    for(int j = b.size()-1;j>=0;j--) B.push_back(b[j]-'0');

    C = add(A,B);
    //从高位到低位输出
    for(int m = C.size()-1;m>=0;m--) cout<<C[m];

    return 0;

}

posted @ 2020-10-18 19:55  secx  阅读(64)  评论(0)    收藏  举报