题解 | #计算一元二次方程#

计算一元二次方程

https://www.nowcoder.com/practice/7da524bb452441b2af7e64545c38dc26

#include <stdio.h>
#include <math.h>
int main() {
    double a, b, c;
    double x1 = 0.00, x2 = 0.00; //方程的根
    double x =0.00,y=0.00;//x表示实部,y表示虚部
    while (scanf("%lf %lf %lf", &a, &b, &c) != EOF) {
        if (a == 0) {
            printf("Not quadratic equation\n");
        } else {
            if (b * b - 4 * a * c == 0) {  //等于零单实根
                if (b==0&&c==0) {
                    printf("x1=x2=0.00\n");
                } else {
                x1 = -1.0 * b / (2.0 * a);
                printf("x1=x2=%.2lf\n", x1);
                }
            } else if (b * b - 4 * a * c > 0) { //大于零双实根
                x1 = (-b - sqrt(b * b - 4 * a * c)) / 2.0 / a;
                x2 = (-b + sqrt(b * b - 4 * a * c)) / 2.0 / a;
                printf("x1=%.2lf;x2=%.2lf\n", x1, x2);
            } else {      //小于零虚根
                x = -b/(2.0*a);
                y = sqrt(4 * a * c - b * b)/(2.0*a);
                printf("x1=%.2lf-%.2lfi;x2=%.2lf+%.2lfi\n",x,y,x,y );
            }
        }
    }
   return 0;
}

全部评论

相关推荐

11-06 10:58
已编辑
门头沟学院 嵌入式工程师
双非25想找富婆不想打工:哦,这该死的伦敦腔,我敢打赌,你简直是个天才,如果我有offer的话,我一定用offer狠狠的打在你的脸上
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务