AcWing 791. 高精度加法--C++
原题链接
简单
作者:
码
,
2020-05-17 11:44:45
,
所有人可见
,
阅读 2602
#include<iostream>
#include<vector>
using namespace std;
vector<int> sum(vector<int>& a,vector<int>& b)
{
vector<int> result;
if(a.size()<b.size()) return sum(b,a);
int t=0;//进位
for(int i=0;i<a.size() || t;i++)//a.size() >= b.size()
{
if(i<a.size()) t+=a[i];
if(i<b.size()) t+=b[i];
result.push_back(t%10);
t/=10;//更新进位
}
return result;
}
int main()
{
string a,b;
vector<int> c,d;
vector<int> result;//存放结果
cin>>a>>b;
//按 个位 十位 百位 ...n位 存放
for(int i=a.size()-1;i>=0;i--) c.push_back(a[i]-'0');//将字符a[i]转换成数值
for(int i=b.size()-1;i>=0;i--) d.push_back(b[i]-'0');//将字符b[i]转换成数值
result=sum(c,d);
for(int i=result.size()-1;i>=0;i--) cout<<result[i];
return 0;
}
貌似add少了一个i[HTML_REMOVED]
#include[HTML_REMOVED]
#include[HTML_REMOVED]
using namespace std;
vector[HTML_REMOVED] add(vector[HTML_REMOVED]& A,vector[HTML_REMOVED]& B){
vector[HTML_REMOVED] C;
int a=0,b=0,t=0;
}
int main(){
vector[HTML_REMOVED] A,B;
string a,b;
cin >>a>>b;
for(int i= a.size()-1;i>=0;i–)A.push_back(a[i]-‘0’);
for(int i= b.size()-1;i>=0;i–)B.push_back(b[i]-‘0’);
auto c=add(A,B);
for(int i= c.size()-1;i>=0;i–)printf(“%d”,c[i]);
}
貌似add少了一个i[HTML_REMOVED]
#include[HTML_REMOVED]
#include[HTML_REMOVED]
using namespace std;
vector[HTML_REMOVED] add(vector[HTML_REMOVED]& A,vector[HTML_REMOVED]& B){
vector[HTML_REMOVED] C;
int a=0,b=0,t=0;
}
int main(){
vector[HTML_REMOVED] A,B;
string a,b;
cin >>a>>b;
for(int i= a.size()-1;i>=0;i–)A.push_back(a[i]-‘0’);
for(int i= b.size()-1;i>=0;i–)B.push_back(b[i]-‘0’);
auto c=add(A,B);
for(int i= c.size()-1;i>=0;i–)printf(“%d”,c[i]);
}