写一个c语言程序,它可以帮我求一元二次方程的两个根
时间: 2024-11-09 12:23:48 浏览: 21
当然可以,下面是一个简单的C语言程序,它使用公式法来计算一元二次方程 ax^2 + bx + c = 0 的两个解。假设a、b和c是你提供的系数。
```c
#include <stdio.h>
#include <math.h>
// 函数声明
double quadratic_root(double a, double b, double c);
int main() {
double a, b, c, discriminant, root1, root2;
printf("请输入一元二次方程的系数:\n");
printf("a = ");
scanf("%lf", &a);
printf("b = ");
scanf("%lf", &b);
printf("c = ");
scanf("%lf", &c);
// 计算判别式
discriminant = pow(b, 2) - 4 * a * c;
// 根据判别式的值确定解的数量
if (discriminant > 0) {
printf("有两个实根:\n");
root1 = (-b + sqrt(discriminant)) / (2 * a);
root2 = (-b - sqrt(discriminant)) / (2 * a);
printf("根1 = %.2lf, 根2 = %.2lf\n", root1, root2);
} else if (discriminant == 0) {
printf("有一个实根:\n");
root1 = -b / (2 * a);
printf("根 = %.2lf\n", root1);
} else { // 复数根
double realPart = -b / (2 * a);
double imaginaryPart = sqrt(-discriminant) / (2 * a);
printf("无实根,有复数根:\n");
printf("根1 = %.2lf + %.2lfi\n", realPart, imaginaryPart);
printf("根2 = %.2lf - %.2lfi\n", realPart, imaginaryPart);
}
return 0;
}
// 二次方程求根函数
double quadratic_root(double a, double b, double c) {
return (-b + sqrt(b * b - 4 * a * c)) / (2 * a);
}
```
阅读全文