柿子饼同学 发表于 2022-5-8 23:14:01

高精度加法

#include <bits/stdc++.h>
using namespace std;

string a, b;
int la, lb, l, note = 0;
int main(){
    ios::sync_with_stdio(0);
    cin >> a >> b;
    la = a.size();
    lb = b.size();
    l = max(la, lb) + 1;
    vector<int> f(l+1, 0);
    vector<int> s(l+1, 0);
    vector<int> ans(l+1, 0);
    for(int i = 0; i < la; i++){
      f = a - '0';
    }
    for(int i = 0; i < lb; i++){
      s = b - '0';
    }
    reverse(f.begin(), f.end());
    reverse(s.begin(), s.end());

    for(int i = 0; i < l; i++){
      ans += (f + s) % 10;
      ans += (f + s) / 10;
    } //竖式计算
    for(int i = 0; i < l; i++){
      cout << ans;
    }
    /*while(ans == 0){
      l--;
    }*/
   
    return 0;
}
代码烂尾了, 调试不管怎么都不管用
不知道有啥问题, qwq

jhq999 发表于 2022-5-9 06:53:50

int main(){
    ios::sync_with_stdio(0);
    cin >> a >> b;
    la = a.size();
    lb = b.size();
    l = max(la, lb) + 1;
    vector<int> f(l, 0);
    vector<int> s(l, 0);
    vector<int> ans(l, 0);
    for(int i = 0; i < la; i++){
      f = a - '0';
    }
    for(int i = 0; i < lb; i++){
      s = b - '0';
    }
   

    for(int i = l-1; i>0; i--){
      ans += f + s;
               
      ans += ans/10;
                ans%=10;
    } //竖式计算
    for(int i = 0; i < l; i++){
      cout << ans;
    }
    /*while(ans == 0){
      l--;
    }*/
   
    return 0;
}

jhq999 发表于 2022-5-9 11:20:51

int main(){
    ios::sync_with_stdio(0);
    cin >> a >> b;
    la = a.size();
    lb = b.size();
    l = max(la, lb) + 1;
    vector<int> f(l, 0);//////////////
    vector<int> s(l, 0);///////////////////
    vector<int> ans(l+1, 0);
    for(int i = 0; i < la; i++){
      f = a - '0';///////////////////
    }
    for(int i = 0; i < lb; i++){
      s = b - '0';///////////////////
    }
    reverse(f.begin(), f.end());
    reverse(s.begin(), s.end());

    for(int i = 0; i < l; i++){
      ans += (f + s);
      ans += ans / 10;
                ans%=10;
    } //竖式计算
        int i = l;
    for(;!ans; i--){}/////////////////////////////
    for(;i>=0;i--)cout << ans;
   
    /*while(ans == 0){
      l--;
    }*/
   
    return 0;
}
页: [1]
查看完整版本: 高精度加法