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

C语言之大数相加

发布时间:2020-12-14 03:59:50 所属栏目:大数据 来源:网络整理
导读:#includestdio.h#includestring.hint main(){int f;int i,an,bn,k;char a[1000],b[1000];int af[1000]={0},bf[1000]={0},c[1000];while(scanf("%s%s",a,b)!=EOF) //输入字符串型的数字{an=strlen(a);bn=strlen(b);k=anbn?an:bn; //k为较长的字符串c[0]=0;f=0
#include<stdio.h>
#include<string.h>
int main()
{
	int f;
	int i,an,bn,k;
	char a[1000],b[1000];
	int af[1000]={0},bf[1000]={0},c[1000];
	while(scanf("%s%s",a,b)!=EOF)   //输入字符串型的数字
	{
		an=strlen(a);
		bn=strlen(b);
		k=an>bn?an:bn;  //k为较长的字符串
		c[0]=0;
		f=0;
		for(i=0;i<an;i++)
			af[i]=a[an-i-1]-'0';
		for(i=0;i<bn;i++)
			bf[i]=b[bn-i-1]-'0';    //将字符串型的数据转换为int型

		for(i=0;i<k;i++)
		{
			c[i]+=(af[i]+bf[i])%10;
			c[i+1]=(af[i]+bf[i])/10;   //如果(af[i]+bf[i])<10,c[i]=(af[i]+bf[i]),否则除10取余
		}
		if(c[i]!=0)
            k++;       //如果需要进位,则k的计数+1
		for(i=k-1;i>=0;i--)
		{
            printf("%d",c[i]);  //倒序输出相加的结果
		}
		printf("n");
		for(i=0;i<k;i++)
			af[i]=bf[i]=0;  //将af,bf初始化为0
	}
	return 0;
}

(编辑:李大同)

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

    推荐文章
      热点阅读