额。。。。。。
1.。。。。scanf("%c",a);输入一个字符???改成%s骚年。。。
2。。。。。for(i=0;i<=101;i++)题目没有说输入的没个数都是101位吧。。如果输入的数没有101位你的c[i]=a[i]+b[i]-96; c[i]系统会给你随机数的。。。。
3。。。。加法是从个位开始加的吧,你的a[0]、b[0]应该是输入数的最高位吧,怎么是他们相加往c[1]进位????。。。。。。
问下你的:::验证的没有错误,可就是执行不了;是什么意思
顺带说下楼上的应该读下题目:Notice that the integers are very large, that means you should not process them by using 32-bit integer. You may assume the length of each integer will not exceed 1000.
#include
#include"string.h"
#define max 1000+10
char a[max],b[max];
int main()
{ int i,j,T,k;
scanf("%d",&T);
for(k=0;k
scanf("%s%s",a,b);
int x=strlen(a);
int y=strlen(b);
for(i=0;i
for(i=0;i
A[i]=s%10;
c=s/10;
}
printf("Case %d:\n%s + %s = ",k+1,a,b);
for( i=max-1;i>=0;i--) if(A[i])break;
for(j=i;j>=0;j--)
printf("%d",A[j]);
printf("\n");
if(k
}
return 0;
}
这是答案
#include
#include
int main()
{
char op1[1002],op2[1002];
int c,i,j,n,m,s1[1002],s2[1002],len1,len2,count;
count=1;
scanf("%d",&n);
m=n;
while(m--)
{
memset(s1,0,1002*sizeof(int));
memset(s2,0,1002*sizeof(int));
scanf("%s",op1);
scanf("%s",op2);
len1=strlen(op1);
len2=strlen(op2);
c=0;
for(i=len1-1;i>=0;i--)
s1[c++]=op1[i]-'0';
c=0;
for(i=len2-1;i>=0;i--)
s2[c++]=op2[i]-'0';
for(i=0;i<1002;i++)
{
s1[i]+=s2[i];
if(s1[i]>=10)
{
s1[i]-=10;
s1[i+1]++;
}
}
printf("Case %d:\n",count++);
printf("%s + %s = ",op1,op2);
for(i=1001;i>=0;i--)
if(s1[i])
break;
for(j=i;j>=0;j--)
printf("%d",s1[j]);
printf("\n");
if(count!=n+1)
printf("\n");
}
return 0;
}
题目呢?