題目鏈接:請點擊
分析:計算sum=A+B,定義整型數組,從低位到高位對sum每3位進行分離,並存入數組。反轉數組,輸出
注1:對於和非前3位,可能需要輸出前導0。如:1000+9=1009 正確輸出:1,009
注2(測試點4):0+0 要輸出0
AC代碼:
#include<iostream>
#include<algorithm>
#include<vector>
#include<cmath>
using namespace std;
int main(){
int a,b,sum,flag=0;
cin>>a>>b;
sum=a+b;
if(sum==0){
cout<<"0";
return 0;
}
if(sum<0) cout<<"-";
sum=abs(sum);
vector<int> v;
while(sum){//從低位到高位獲取每位數字
v.push_back(sum%1000);
sum/=1000;
}
reverse(v.begin(),v.end());
for(int i=0;i<v.size();i++){
if(flag) cout<<",";
if(i!=0) printf("%03d",v[i]);
else cout<<v[i];
flag=1;
}
return 0;
}