题目链接:https://www.patest.cn/contests/pat-a-practise/1001
题意,给我们两个-1000000 ~ 1000000的数,求出两个数的和,结果按照每三位一个","的形式输出。
题意非常简单,且这两个数的范围以及和的范围明显不会超过int的范围,所以我们首先直接以int的形式输入两个数并计算这两个数的和,接下来我们取出每一位,当位数对3取模等于1且位数不为1的时候,我们添加",",即可得到解决此题。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 7;
int num[7];
int main() {
int a, b, sum, len, tmp;
while(scanf("%d%d", &a, &b) !=EOF) {
sum = a + b;
len = 0;
tmp = sum<0? 1 : 0;
sum = sum<0? -sum : sum;
if(sum == 0) {
printf("0\n");
continue;
}
while(sum) {
num[len++] = sum % 10;
sum /= 10;
}
if(tmp) {
printf("-");
}
for(int i=len-1; i>=0; i--) {
printf("%d", num[i]);
if((i+1) % 3 == 1 && i != 0) {
printf(",");
}
}
printf("\n");
}
}