1949 Problem A a+b

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a845717607/article/details/89509745

问题 A: a+b

时间限制: 1 Sec  内存限制: 32 MB

题目描述

实现一个加法器,使其能够输出a+b的值。

输入

输入包括两个数a和b,其中a和b的位数不超过1000位。

输出

可能有多组测试数据,对于每组数据,
输出a+b的值。

样例输入

6 8
2000000000 30000000000000000000

样例输出

14
30000000002000000000

经验总结

基础题~~

AC代码

#include <cstdio>
#include <cstring>
struct bign
{
	int d[1010];
	int len;
	bign()
	{
		memset(d,0,sizeof(d));
		len=0;
	}
};
bign change(char s[])
{
	bign a;
	a.len=strlen(s);
	for(int i=0;i<a.len;i++)
		a.d[i]=s[a.len-i-1]-'0';
	return a;
}
bign add(bign a,bign b)
{
	bign c;
	int carry=0;
	for(int i=0;i<a.len||i<b.len;i++)
	{
		int temp=a.d[i]+b.d[i]+carry;
		c.d[c.len++]=temp%10;
		carry=temp/10;
	}
	if(carry!=0)
		c.d[c.len++]=carry;
	return c;
}
int main()
{
	char s1[1010],s2[1010];
	while(~scanf("%s%s",s1,s2))
	{
		bign a=change(s1);
		bign b=change(s2);
		bign c=add(a,b);
		for(int i=c.len-1;i>=0;i--)
			printf("%d",c.d[i]);
		printf("\n");
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/a845717607/article/details/89509745
今日推荐