0
点赞
收藏
分享

微信扫一扫

高精度基础 加法

大雁f 2022-02-16 阅读 85



  1. #include<iostream>
  2. #include<string>
  3. using namespace std;
  4. string a,b;
  5. void re(){
  6.     //翻转、补零操作
  7.     int max_length=a.length()>b.length()? a.length():b.length();
  8.     string str;
  9.     for(int i=0;i<a.length();i++){
  10.         str+=a[a.length()-1-i];
  11.     }
  12.     a=str;str="";
  13.     for(int i=0;i<b.length();i++){
  14.         str+=b[b.length()-1-i];
  15.     }
  16.     b=str;str="";

  17.     for(int i=a.length();i<max_length;i++){
  18.         a+="0";
  19.     }
  20.     for(int i=b.length();i<max_length;i++){
  21.         b+="0";
  22.     }
  23. }
  24. string addtion(){
  25.     int c=0;
  26.     string r;
  27.     for(int i=0;i<a.length();i++ ){
  28.         int x=a[i]-'0';
  29.         int y=b[i]-'0';
  30.         int jieguo=(x+y+c)%10;
  31.         c=(x+y+c)/10;
  32.         r+=(char)(jieguo+'0');
  33.     }
  34.     if(c==0)return r;
  35.     return r+=(char)(c+'0');
  36. }
  37. int main(){
  38.     cin>>a>>b;
  39.     re();
  40.     string str=addtion();
  41.     for(int i=0;i<str.length();i++){
  42.         cout<<str[str.length()-1-i];
  43.     }

  44.     return 0;
  45. }


举报

相关推荐

0 条评论