PAT问题:A+B

题目描述
给定两个整数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
#include
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='0'&&s1[i]<='9')
			a=a*10+s1[i]-'0';
		}
		if(s1[0]=='-')
		a=-a;
		for(i=0;i='0'&&s2[i]<='9')
			b=b*10+s2[i]-'0';
		}
		if(s2[0]=='-')
		b=-b;
		
		printf("%ld",a+b);
	}
		
	return 0;
} 

你可能感兴趣的:(个人刷题)