对于一元二次方程的解,并没有难的地方,不过有一个细节需要注意。
浮点数在与零值进行比较时,不能将浮点变量用" == "或" != "与任何数字比较。不管是float还是double类型的变量,都有精度限制。
所以在比较时应将其设法转化成" >= "或" <= "形式。
指针变量在与零值比较时,应将指针变量用" == "或" != "与NULL 值比较。
布尔变量与零值比较时,不可直接与TRUE或FALSE或0、1进行比较。if(flag)表示flad为真,if(!flag)表示flag为假。
整形变量则用" == "或" != "直接与0进行比较。
#include <stdio.h>
#include <math.h>
#define EXP 0.00000001
int main()
{
double a = 0.0;
double b = 0.0;
double c = 0.0;
scanf_s("%lf%lf%lf", &a, &b, &c);
if ((a >= -EXP) && (a <= EXP))
printf("该方程不是一元二次方程\n");
else
{
double disc = b*b - 4 * a*c;
if (disc > 0)
printf("x1=%lf,x2=%lf\n",
(-b + sqrt(disc)) / (2 * a),
(-b - sqrt(disc)) / (2 * a));
else
{
if ((disc >= -EXP) && (disc <= EXP))
printf("x=%lf\n", (-b / (2 * a)));
else
printf("该方程有两个共轭的复根\n");
}
}
return 0;
}