PAT 1001 A+B Format (20分) to_string()
题目
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
题目解析
给出两个数字(-1000000
到1000000
之间),计算他们的和,以标准格式输出(形如 99,999,999
)
首先,两个数都是
-1000000
到1000000
之间,所以直接用int
保存求和即可,不会溢出然后为了输出方便,将其转为字符串,(
to_string()
是c++11引入的新方法)从前往后逐个输出字符,如果是负数,第一个字符是
'-'
什么时候要输出
','
,标准格式是从后往前三个一输出,假设转成字符串后的长度为len
,那么len % 3
就是最前面多出的长度,也就是第一个','
出现的位置,后面的都可以三个一组,就隔三个,输出一个','
。比如
12,345,666
,len = 8
,len % 3 = 2
,所以第2个数字后面加','
,第5个数字后面加 ',',第 8 个数字后加 ',',但是第8个是最后一个数字,所以要排除。所以 条件就是i % 3 == len % 3
,但是因为我们的下标是从0开始的,而我们是数数字个数判断,所以应该是(i + 1) % 3 == len % 3 && (i != len % 3)
代码
#include <iostream>
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;
// 标准化格式 -xx,123,999
if ((i + 1) % 3 == len % 3 && i != len - 1)
cout << ",";
}
return 0;
}
最新文章
- java 过滤器Filter
- django--forms
- mysql删除开放用户权限
- android调试工具DDMS的使用详解
- cocos布局分析
- 解决本地tomcat服务器内存不足问题
- Android drawable xml 各种小知识
- C#学习之在辅助线程中修改UI控件----invoke方法
- 关于RESTful接口api的设计
- PHP初入,(特效的使用)
- spring之集合注入
- route路由的顺序问题了数据包的转发流程
- Collections.sort自定义排序的使用方法
- 2018-2019-2 网络对抗技术 20165206 Exp4 恶意代码分析
- Vim使用技巧:将Tab转换为4个空格
- Unity 5 使用Roslyn编译器支持C# 7
- [Jenkins]IOS构建机配置记录
- python 基础知识点一
- EMbedding
- sql server2008系统表详细说明sys.开头的表