C语言求解一元二次方程的根
以下是一个完整的C语言程序,用于求解一元二次方程 ax² + bx + c = 0 的根:

(图片来源网络,侵删)
#include <stdio.h>
#include <math.h>
int main() {
double a, b, c;
double discriminant, root1, root2, realPart, imagPart;
// 输入方程系数
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("方程有两个不同的实数根:\n");
printf("root1 = %.2lf\n", root1);
printf("root2 = %.2lf\n", root2);
} else if (discriminant == 0) {
// 两个相同的实数根
root1 = root2 = -b / (2 * a);
printf("方程有两个相同的实数根:\n");
printf("root1 = root2 = %.2lf\n", root1);
} else {
// 复数根
realPart = -b / (2 * a);
imagPart = sqrt(-discriminant) / (2 * a);
printf("方程有两个复数根:\n");
printf("root1 = %.2lf + %.2lfi\n", realPart, imagPart);
printf("root2 = %.2lf - %.2lfi\n", realPart, imagPart);
}
return 0;
}
程序说明
-
输入处理:程序首先要求用户输入一元二次方程的三个系数 a, b, c。
-
判别式计算:计算判别式 Δ = b² - 4ac,它决定了方程根的性质。
-
三种情况处理:
- Δ > 0:方程有两个不同的实数根
- Δ = 0:方程有两个相同的实数根(重根)
- Δ < 0:方程有两个共轭复数根
-
输出结果:根据不同情况输出方程的根。
(图片来源网络,侵删)
使用示例
示例1:两个不同的实数根
输入:
1 -5 6
输出:
方程有两个不同的实数根:
root1 = 3.00
root2 = 2.00
示例2:两个相同的实数根
输入:
1 2 1
输出:

(图片来源网络,侵删)
方程有两个相同的实数根:
root1 = root2 = -1.00
示例3:复数根
输入:
1 2 5
输出:
方程有两个复数根:
root1 = -1.00 + 2.00i
root2 = -1.00 - 2.00i
注意:此程序需要链接数学库(在Linux/macOS下使用-lm选项编译),
gcc quadratic_equation.c -o quadratic -lm
