C语言 求纠错!!!! 计算数值较大的a+b结果,
#include<stdio.h>#include<stdlib.h>#include<string.h>voidReverse(charn[]);intmain(voi...
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void Reverse(char n[]);
int main(void)
{
char A[500];
char B[500];
char C[501];
int x,y,z;
int state=0;
int ln;
while(scanf("%s%s",&A,&B)==2)
{
x=strlen(A)-1;
y=strlen(B)-1;
ln=(x>y?1:2);
z=0;
while(x>=0 && y>=0)
{
C[z]=A[x]+B[y]-96;
if(state==1)
{
C[z]++;
}
if(C[z]>=10)
{
C[z]-=10;
state=1;
}
else
{
state=0;
}
C[z]+=46;
x--;
y--;
z++;
}
if(ln==1)
{
while(x>=0)
{
C[z]=A[x];
if(state==1)
{
C[z]++;
}
x--;
z++;
state=0;
}
}
if(ln==2)
{
while(y>=0)
{
C[z]=B[y];
if(state==1)
{
C[z]++;
}
y--;
z++;
state=0;
}
}
C[z]='\0';
Reverse(C);
printf("%s\n",C);
}
system("PAUSE");
return 0;
}
void Reverse(char n[])
{
int i,j,k;
for(i=0,j=(strlen(n)-1);i<strlen(n)/2;i++,j--)
{
k=n[i];
n[i]=n[j];
n[j]=k;
}
}
跪谢各位大侠帮我纠错。 展开
#include<stdlib.h>
#include<string.h>
void Reverse(char n[]);
int main(void)
{
char A[500];
char B[500];
char C[501];
int x,y,z;
int state=0;
int ln;
while(scanf("%s%s",&A,&B)==2)
{
x=strlen(A)-1;
y=strlen(B)-1;
ln=(x>y?1:2);
z=0;
while(x>=0 && y>=0)
{
C[z]=A[x]+B[y]-96;
if(state==1)
{
C[z]++;
}
if(C[z]>=10)
{
C[z]-=10;
state=1;
}
else
{
state=0;
}
C[z]+=46;
x--;
y--;
z++;
}
if(ln==1)
{
while(x>=0)
{
C[z]=A[x];
if(state==1)
{
C[z]++;
}
x--;
z++;
state=0;
}
}
if(ln==2)
{
while(y>=0)
{
C[z]=B[y];
if(state==1)
{
C[z]++;
}
y--;
z++;
state=0;
}
}
C[z]='\0';
Reverse(C);
printf("%s\n",C);
}
system("PAUSE");
return 0;
}
void Reverse(char n[])
{
int i,j,k;
for(i=0,j=(strlen(n)-1);i<strlen(n)/2;i++,j--)
{
k=n[i];
n[i]=n[j];
n[j]=k;
}
}
跪谢各位大侠帮我纠错。 展开
2个回答
展开全部
我写个,你看看
x=strlen(A)-1;
y=strlen(B)-1;
if x<y {a=x;b=y;}else {a=y;b=x;} z=0;
while(a>=z)
{ C[z]+=A[x]+B[y]-96;
C[z+1]=int(C[z]/10);//高一位数值取初值(进位设为初值,没有进位则为0初值)
C[z]=C[z] mod 10;// 当前位数值;
z++; x--;y--;
}
if C[b+1]<>0 b++; //两数加的和的位数有两种情况: 与大数相同,比大数多一位。
输出则 C[0]到C[b].
x=strlen(A)-1;
y=strlen(B)-1;
if x<y {a=x;b=y;}else {a=y;b=x;} z=0;
while(a>=z)
{ C[z]+=A[x]+B[y]-96;
C[z+1]=int(C[z]/10);//高一位数值取初值(进位设为初值,没有进位则为0初值)
C[z]=C[z] mod 10;// 当前位数值;
z++; x--;y--;
}
if C[b+1]<>0 b++; //两数加的和的位数有两种情况: 与大数相同,比大数多一位。
输出则 C[0]到C[b].
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询