加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

大数的加法

发布时间:2020-12-14 02:54:34 所属栏目:大数据 来源:网络整理
导读:输入两个很大的数字(这两个数字不能以数字的形式存进计算机)并对他们求和; #include "stdio.h"#include "string.h"int main(){char a[10000],b[10000];int result[20000];int i,j,k;i=0;while((a[i++]=getchar())!='n');a[i-1]='';i=0;while((b[i++]=g

输入两个很大的数字(这两个数字不能以数字的形式存进计算机)并对他们求和;

#include "stdio.h"
#include "string.h"
int main()
{
	char a[10000],b[10000];
	int result[20000];
	int i,j,k;
	i=0;
	while((a[i++]=getchar())!='n');
	a[i-1]='';
	i=0;
	while((b[i++]=getchar())!='n');
	b[i-1]='';
	for(i=0;i<200;i++)
		result[i]=0;

	for(i=strlen(a)-1,j=strlen(b)-1,k=0;i>=0 && j>=0;i--,j--,k++)
	{	
		if((a[i]-'0')+(b[j]-'0')+result[k]>9)
			result[k+1]=result[k+1]+1;
		result[k]=((a[i]-'0')+(b[j]-'0')+(result[k]))%10;
	}
	if(i<0)
        {
            for(;j>=0;j--,k++)
			{
				if(((b[j]-'0')+result[k])>9)
					result[k+1]=1;
                result[k]=((b[j]-'0')+result[k])%10;
			}
        }
        if(j<0)
        {
            for(;i>=0;i--,k++)
			{
				if(((a[i]-'0')+result[k])>9)
					result[k+1]=1;
                result[k]=((a[i]-'0')+result[k])%10;
			}
        }
        
        
	if(result[k]!=0)
	{
		result[k+1]='';
		for(i=k;i>=0;i--)
			printf("%d",result[i]);
	}
	else
	{
		result[k]='';
		for(i=k-1;i>=0;i--)
			printf("%d",result[i]);
	}
	putchar('n');

	return 0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读