Codeup 墓地——问题 B: A+B

问题 B: A+B

时间限制: 1 Sec  内存限制: 32 MB
提交: 1640  解决: 782
[提交][状态][讨论版][命题人:外部导入]

题目描述

给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号","隔开。
现在请计算A+B的结果,并以正常形式输出。

输入

输入包含多组数据数据,每组数据占一行,由两个整数A和B组成(-10^9 < A,B < 10^9)。

输出

请计算A+B的结果,并以正常形式输出,每组数据占一行。

样例输入

-234,567,890 123,456,789
1,234 2,345,678

样例输出

-111111101
2346912

PS:我开始写的时候,又想复杂了。本来只需10分钟不到的时间解决,被我弄成25分钟!
其中出错的地方如下:
1、在遍历字符串的时候,我管了',',和'-'的情况,实际上?要你管吗?不需要啊,你只需要碰到字符为'0'-'9'的时候你才需要管!
2、在边遍历边计算这个数的值的时候,我犯了个很大的错误!我竟用i来存储这个中间值!应该用result的

知识点补充:
本题用int 型可以表示10^9的数,保够!最适合的才是最好的。

Int16 值类型表示值介于 -32768 到 +32767 之间的有符号整数。
Int32 值类型表示值介于 -2,147,483,648 到 +2,147,483,647 之间的有符号整数。
Int64 值类型表示值介于 -9,223,372,036,854,775,808 到 +9,223,372,036,854,775,807 之间的整数。
int是32位整数
上限是 (2^31)-1
下限是 -2^31
 
long long能表示2的64个数,因为要考虑正负数,所以是 -2^63 ~ (2^63)-1,即  范围负的2的32次方减1至2的32次方减1

代码如下:已经提交成功
 1 #include <iostream>
 2 #include<string>
 3 /* run this program using the console pauser or add your own getch, system("pause") or input loop */
 4 using namespace std;
 5 
 6 
 7 int s2i(string a){
 8     int result=0;
 9     int i;
10     for(i=0;i<=a.length();i++){
11         if(a[i]>='0'&&a[i]<='9'){
12             result=(result*10)+(a[i]-'0');
13         }
14     }
15     //','管它干啥?别管
16     if(a[0]=='-'){
17         result=-result;
18     }
19     return result;
20 }
21 int main(int argc, char** argv) {
22     string sa,sb;
23     int _a,_b;
24     while(cin>>sa>>sb){
25         _a = s2i(sa);
26         _b = s2i(sb);
27         
28         cout<<_a+_b<<endl;
29     }
30     return 0;
31 }

 



转载于:https://www.cnblogs.com/industrial-fd-2019/p/10599549.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值