(3)求一元二次方程的根:输入参数a、b、c,求一元二次方程ax+bx+c=0的根。①如果方程有两个不相等的实数根,则每行输出一个根,先大后小;
20如果方程有两个不相等复数根,则每行按照格式“实部+虚部i”输出一个根,输出虚部为正的,后输出虚部为负的;
3如果方程只有一个根,则直接输出此根;
④如果系数都为0,则输出“Zero Equation”;
5如果a和b为0,c不为0,则输出“Not An Equation”。
输入输出示例(运行5次)
#include <math.h>
int main()
{
printf("Enter a, b, c:");
double a = 0, b = 0, c = 0;
while (scanf("%lf%lf%lf", &a, &b, &c) != EOF)
{
double x1 = 0;
double x2 = 0;
double m1 = -b / (2.0 * a);
double m2 = (b * b - 4.0 * a * c);
if (m2 < 0)
{
m2 = sqrt(-m2);
m2 = m2 / 2 / a;
printf("-%.2lf + %.2lfi\n", m1, m2);
printf("-%.2lf - %.2lfi\n", m1, m2);
}
else if (m2 == 0 && b != 0)
{
printf("%.2lf", m1);
}
else if (m2 > 0)
{
x1 = m1 + m2;
x2 = m1 - m2;
printf("%.2lf\n", x1);
printf("%.2lf\n", x2);
}
else if (a == 0 && b == 0 && c == 0)
{
printf("Zero Equation\n");
}
else if (a == 0 && b == 0 && c != 0)
{
printf("Not An Equation\n");
}
}
return 0;
}