作者:
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):