各位高手帮忙看一下,这个C语言小程序有什么错误
#include<stdio.h>main(){doublea,b,c,d;printf("xrabc\n");scanf("%f,%f,%f",&a,&b,&c);d=...
#include<stdio.h>
main()
{double a,b,c,d;
printf("xrabc\n");
scanf("%f,%f,%f",&a,&b,&c);
d=a+b+c;
printf("a=%f,b=%f,c=%f,d=%f",a,b,c,d);
} 输入abc的值以后,运行结果是错误的,显示出的d值不是abc的和,就连显示出的abc的值都跟输入的值不一样,郁闷! 展开
main()
{double a,b,c,d;
printf("xrabc\n");
scanf("%f,%f,%f",&a,&b,&c);
d=a+b+c;
printf("a=%f,b=%f,c=%f,d=%f",a,b,c,d);
} 输入abc的值以后,运行结果是错误的,显示出的d值不是abc的和,就连显示出的abc的值都跟输入的值不一样,郁闷! 展开
2个回答
展开全部
#include<stdio.h>
void main()
{float a,b,c,d;
printf("xrabc\n");
scanf("%f,%f,%f",&a,&b,&c);
d=a+b+c;
printf("a=%f,b=%f,c=%f,d=%f",a,b,c,d);
}
类型不匹配,你按浮点型输出双精度型是不行的,你sizeof()一下double的值是8字节,float是4,浮点型是装不下double的。
或者:
#include<stdio.h>
void main()
{double a,b,c,d;
printf("xrabc\n");
printf("%d\n",sizeof(a));
printf("%d",sizeof(double));
scanf("%lf,%lf,%lf",&a,&b,&c);
d=a+b+c;
printf("a=%lf,b=%lf,c=%lf,d=%lf",a,b,c,d);
}
lf(长浮点型)就可以了
void main()
{float a,b,c,d;
printf("xrabc\n");
scanf("%f,%f,%f",&a,&b,&c);
d=a+b+c;
printf("a=%f,b=%f,c=%f,d=%f",a,b,c,d);
}
类型不匹配,你按浮点型输出双精度型是不行的,你sizeof()一下double的值是8字节,float是4,浮点型是装不下double的。
或者:
#include<stdio.h>
void main()
{double a,b,c,d;
printf("xrabc\n");
printf("%d\n",sizeof(a));
printf("%d",sizeof(double));
scanf("%lf,%lf,%lf",&a,&b,&c);
d=a+b+c;
printf("a=%lf,b=%lf,c=%lf,d=%lf",a,b,c,d);
}
lf(长浮点型)就可以了
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询