1001 A+B Format (20 分)

简介: 1001 A+B Format (20 分)

1001 A+B Format (20 分)


Calculate a+b and output the sum in standard format -- that is, the digits must be separated into groups of three by commas (unless there are less than four digits).

Input Specification:

Each input file contains one test case. Each case contains a pair of integers a and b where −106≤a,b≤106. The numbers are separated by a space.

Output Specification:

For each test case, you should output the sum of a and b in one line. The sum must be written in the standard format.

Sample Input:

-1000000 9

Sample Output:

-999,991

题目分析:

计算两个整数的和,并且这两个整数范围很正常,不大于10^6,

有一点需要注意的是输出需要用题目要求的格式(每3位用逗号分割),可以使用字符串转换把a,b的和转换成字符串,然后对字符串进行操作。

 

#include<iostream>
#include<string>
using namespace std;
int main()
{
  int a,b;
  cin >> a >> b;
  string s = to_string(a + b);
  int len = s.length();
  for (int i = 0; i < len; i++)
  {
     cout<<s[i];
    if (s[i] == '-') continue;
    if ((i + 1) % 3 == len % 3 && i != len - 1)
      cout << ',';
  }
  return 0;
}


关键语句:

if ((i + 1) % 3 == len % 3 && i != len - 1)

i != len - 1 很好理解,就是对最后一位的判断。

((i + 1) % 3 == len % 3 就是在找逗号的位置,i从0开始,所以i+1,因为输出是从前往后输出,索引要用 len%3 找逗号的位置。

比如12,345 ;   12,345,678  

相关文章
|
5月前
|
C语言
C语言--生日日期输出--年月日,一行输出--之间没有间隔,若月份为个位,在前面添加0
C语言--生日日期输出--年月日,一行输出--之间没有间隔,若月份为个位,在前面添加0
|
5月前
1043 输出PATest (20 分)
1043 输出PATest (20 分)
|
6月前
|
Java
java将输入的字符串时间提前一天,再以字符串形式输出。输入时间格式为:yyyy-MM-dd
java将输入的字符串时间提前一天,再以字符串形式输出。输入时间格式为:yyyy-MM-dd
39 2
|
6月前
DATE_FORMAT函数使用
DATE_FORMAT函数使用
260 0
1001. A+B Format(20分)
1001. A+B Format(20分)
90 0
|
Python
盘点一个`07Apr2022`格式日期转换的基础题目
盘点一个`07Apr2022`格式日期转换的基础题目
217 0
盘点一个`07Apr2022`格式日期转换的基础题目
|
C语言 C++
1043 输出PATest (20 分)
给定一个长度不超过 104 的、仅由英文字母构成的字符串。请将字符重新调整顺序,按 PATestPATest.... 这样的顺序输出,并忽略其它字符。当然,六种字符的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按 PATest 的顺序打印,直到所有字符都被输出。
96 0
【1144】The Missing Number (20 分)
【1144】The Missing Number (20 分) 【1144】The Missing Number (20 分)
78 0
【1117】Eddington Number (25分)【模拟】
【1117】Eddington Number (25分)【模拟】 【1117】Eddington Number (25分)【模拟】
88 0
【1126】Eulerian Path (25分)【连通图】
1)如果是一个连通图,则只需要一次DFS即可完成遍历。 (2)可以用DFS判断一个无向图是否
157 0