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<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;
} 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值