楼主:
PanYX (Panpeter)
2019-01-02 23:34:59开发平台(Platform): (Ex: Win10, Linux, ...)
Win10
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
DEV-C++
额外使用到的函数库(Library Used): (Ex: OpenGL, ...)
问题(Question):
目前已知a,b,c变量宣告为单精度浮点数float答案是正确的
可是为什么不能把a,b,c变量宣告为double倍精度浮点数?
喂入的资料(Input):
a=1,b=6,c=2
预期的正确结果(Expected Output):
此方程式有两个实根:x=-0.354248762,x=-5.645751
错误结果(Wrong Output):
没有实根
程式码(Code):(请善用置底文网页, 记得排版,禁止使用图档)
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main (void)
{
double a,b,c;
double value,r1,r2;
printf("请输入a,b,c的值:");
scanf("%f,%f,%f",&a,&b,&c);
value = b*b-4*a*c;
r1=(-b+(float)(sqrt(b*b-4*a*c)))/(2*a);
r2=(-b-(float)(sqrt(b*b-4*a*c)))/(2*a);
if(value>0)
{
printf("此方程式有两个实根:x=%f,x=%f\n",r1,r2);
}
else if(value==0)
{
r1=(-b)/(2*a);
printf("此方程式有两个相等实根:x=%f\n",r1);
}
else
{
printf("没有实根\n");
}
system("pause");
return 0;
}
补充说明(Supplement):