题解 | #计算一元二次方程#
计算一元二次方程
https://www.nowcoder.com/practice/7da524bb452441b2af7e64545c38dc26
#include<stdio.h> #include<math.h> int main() { double a = 0; double b = 0; double c = 0; while (scanf("%lf%lf%lf", &a, &b, &c) != EOF) { if (a == 0) printf("Not quadratic equation\n"); else { double delta = pow(b, 2) - 4 * a * c; double x1 = (-b - sqrt(delta)) / (2 * a); double x2 = (-b + sqrt(delta)) / (2 * a); if (delta == 0) { double x = -b / (2 * a); if (x1 == 0) printf("x1=x2=0.00\n"); else printf("x1=x2=%.2f\n", x1);; } else if (delta > 0) { printf("x1=%.2f;x2=%.2f\n", x1, x2); } else { double A = -b / (2 * a); double B = sqrt(-delta) / (2 * a); printf("x1=%.2f-%.2fi;x2=%.2f+%.2fi\n", A, B, A, B); } } } return 0; }