高精度加法
#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 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;
} 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]