代码:借鉴了柳婼的思路
#include<iostream>
using namespace std;
int main() {
string s,s1,s2,ans;
cin>>s>>s1>>s2;
// string s(num, char):生成num个c字符的字符串
string a1(s.size()-s1.size(),'0');
string a2(s.size()-s2.size(),'0');
s1=a1+s1,s2=a2+s2;
int jinwei=0,flag=0;
for(int i=s.size()-1;i>=0;i--){
int mod=(s[i]=='0')?10:(s[i]-'0');
ans.insert(ans.begin(),(s1[i]-'0'+s2[i]-'0'+jinwei)%mod+'0');
jinwei=(s1[i]-'0'+s2[i]-'0'+jinwei)/mod;
}
if(jinwei>0) ans.insert(ans.begin(),jinwei%10+'0'); //测试点
for(int i=0;i<ans.size();i++){
if (ans[i] != '0' || flag == 1) { //测试点
flag = 1;
cout << ans[i];
}
}
if(flag==0) cout<<"0"; // 测试点5
return 0;
}
太坑了,又踩坑儿里去了…