一元二次方程c语言程序完整代码
时间: 2024-10-12 20:16:32 浏览: 49
c语言解一元二次方程代码
5星 · 资源好评率100%
在C语言中,编写一个用于求解一元二次方程的完整代码通常会涉及到计算根的公式,即如果有一个一般形式的二次方程 `ax^2 + bx + c = 0`,它的根可以通过下面的公式计算:
\[ x = \frac{-b \pm \sqrt{b^2 - 4ac}}{2a} \]
以下是完整的C语言程序示例:
```c
#include <stdio.h>
#include <math.h> // 引入数学库,使用sqrt函数
// 函数声明,定义求解二次方程的方法
double solve_quadratic(double a, double b, double c);
int main() {
double a, b, c, discriminant, root1, root2;
// 输入二次方程的系数
printf("请输入二次方程的系数 (a, b, c): ");
scanf("%lf %lf %lf", &a, &b, &c);
// 计算判别式
discriminant = b * b - 4 * a * c;
if (discriminant > 0) { // 两个实数根的情况
root1 = (-b + sqrt(discriminant)) / (2 * a);
root2 = (-b - sqrt(discriminant)) / (2 * a);
printf("方程的两个实数根分别为: %.2lf 和 %.2lf\n", root1, root2);
} else if (discriminant == 0) { // 双重实数根(重根)
root1 = -b / (2 * a);
printf("方程有一个实数根: %.2lf\n", root1);
} else { // 两个复数根
double realPart = -b / (2 * a);
double imaginaryPart = sqrt(-discriminant) / (2 * a);
printf("方程有两个共轭复数根: %.2lf + %.2lfi 和 %.2lf - %.2lfi\n",
realPart, imaginaryPart, realPart, imaginaryPart);
}
return 0;
}
// 定义求解二次方程的函数
double solve_quadratic(double a, double b, double c) {
return (-b + sqrt(b * b - 4 * a * c)) / (2 * a); // 返回较大的根
}
```
阅读全文