题目描述
给定两个整数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
这也是我做的算法笔记书上的第一道题,讲真这道题我是看了题解才想出来的,,,
代码其实并不难,我先贴下;
主要去存储那两个数字的时候用数组实现是很好的,然后再想办法怎么去掉“,”;之后在想办法怎么把数字提取出来相加;
其实就一步关键的,根据ASCAL码来数字0-9是顺序相连的10个数字,所以可以定义,0<=S1<=9;就可以实现对所有数字的提取,在之后就是想办法累乘起来;把数字还原并判断第一个数字是不是负号;
#include<stdio.h>
#include<string.h>
char s1[20],s2[20];//定义两个字符数组来存储数字元组;
int len1,len2;
int long long a,b;//当存储的数值足够大的时候会最好在外面定义全局变量,
int main(){
int i;
while(scanf("%s%s",s1,s2)!=EOF){
a=b=0;//定义a,b用来存储接下来的数值
len1=strlen(s1);
len2=strlen(s2);
for(i=0;i<len1;i++){//关键算法
if(s1[i]>='0'&&s1[i]<='9')
a=a*10+s1[i]-'0';
}
if(s1[0]=='-')
a=-a;
for(i=0;i<len2;i++){
if(s2[i]>='0'&&s2[i]<='9')
b=b*10+s2[i]-'0';
}
if(s2[0]=='-')
b=-b;
printf("%ld",a+b);
}
return 0;
}