题目链接: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"); } }