编程求解一元二次方程的根,计算精度要求达到10-10。 (不得用fabs函数)
时间: 2023-05-17 07:04:53 浏览: 69
一元二次方程求根
可以使用以下代码来求解一元二次方程的根,计算精度达到10^-10:
#include <stdio.h>
#include <math.h>
int main() {
double a, b, c, delta, x1, x2;
scanf("%lf %lf %lf", &a, &b, &c);
delta = b * b - 4 * a * c;
if (delta < 0) {
printf("无实数根\n");
} else if (delta == 0) {
x1 = x2 = -b / (2 * a);
printf("x1 = x2 = %.10lf\n", x1);
} else {
x1 = (-b + sqrt(delta)) / (2 * a);
x2 = (-b - sqrt(delta)) / (2 * a);
printf("x1 = %.10lf, x2 = %.10lf\n", x1, x2);
}
return 0;
}
这段代码可以求解一元二次方程 ax^2 + bx + c = 0 的根,其中 a、b、c 分别为方程的系数,delta 为判别式,x1、x2 分别为方程的两个根。如果 delta 小于 0,则方程无实数根;如果 delta 等于 0,则方程有一个重根;如果 delta 大于 0,则方程有两个不同的实数根。
阅读全文