计算一元二次方程的根

输入描述:

多组输入,一行,包含三个浮点数a, b, c,以一个空格分隔,表示一元二次方程ax2 + bx + c = 0的系数。

输出描述:

针对每组输入,输出一行,输出一元二次方程ax2 + bx +c = 0的根的情况。

  如果a = 0,输出“Not quadratic equation”;

  如果a ≠  0,分三种情况:

△ = 0,则两个实根相等,输出形式为:x1=x2=...

△  > 0,则两个实根不等,输出形式为:x1=...;x2=...,其中x1  <=  x2。

△  < 0,则有两个虚根,则输出:x1=实部-虚部i;x2=实部+虚部i,即x1的虚部系数小于等于x2的虚部系数,实部为0时不可省略。实部= -b / (2*a),虚部= sqrt(-△ ) / (2*a)

所有实数部分要求精确到小数点后2位,数字、符号之间没有空格。

#include
#include
int main() {
    float a, b,c,d,e;
    while(scanf("%f %f %f",&a,&b,&c)!=EOF)
{
    d=-b/(2*a);
    if(d==-0)
        d=0;
    e=sqrt(b*b-4*a*c);
    if(a==0)
        printf("Not quadratic equation");
    else
    {   
        if(b*b-4*a*c==0)
            printf("x1=x2=%.2f\n",d);
        else if(b*b-4*a*c>0)
            printf("x1=%.2f;x2=%.2f",d-e/(2*a),d+e/(2*a));
        else
            {
            e=sqrt(-(b*b-4*a*c));
            printf("x1=%.2f-%.2fi;x2=%.2f+%.2fi",d,e/(2*a),d,e/(2*a));
            }
    } ;
}    
    return 0;
}

你可能感兴趣的:(c语言)