求 a * x^2 + b * x + c = 0 方程的根。代码用stdio.h不带文字表述
时间: 2023-09-04 11:12:00 浏览: 68
好的,以下是一个求解一元二次方程的 C 代码:
```c
#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("No real roots.\n");
} else if (delta == 0) {
x1 = x2 = -b / (2 * a);
printf("One real root: %lf.\n", x1);
} else {
x1 = (-b + sqrt(delta)) / (2 * a);
x2 = (-b - sqrt(delta)) / (2 * a);
printf("Two real roots: %lf, %lf.\n", x1, x2);
}
return 0;
}
```
其中,`a`,`b`,`c` 分别代表一元二次方程 `a * x^2 + b * x + c = 0` 中的系数,`delta` 为判别式,`x1`,`x2` 分别为方程的两个根。程序会从标准输入中读入系数,然后输出方程的根。
你可以将以上代码保存为一个 `.c` 文件并编译运行。
相关问题
用c语言编写求二元一次方程 a * x ^2+ b * x + c =0的根。
可以使用公式法求解二元一次方程的根:
1. 先计算判别式 delta = b^2 - 4 * a * c
2. 如果 delta < 0,则方程无实根;
3. 如果 delta = 0,则方程有唯一的实根 x = -b / (2*a)
4. 如果 delta > 0,则方程有两个实根 x1 = (-b + sqrt(delta)) / (2*a),x2 = (-b - sqrt(delta)) / (2*a)
下面是用 C 语言实现的代码:
```c
#include <stdio.h>
#include <math.h>
int main() {
double a, b, c, delta, x1, x2;
printf("请输入二元一次方程的系数 a, b, c:");
scanf("%lf %lf %lf", &a, &b, &c);
delta = b * b - 4 * a * c;
if (delta < 0) {
printf("该方程无实根。\n");
} else if (delta == 0) {
x1 = -b / (2 * a);
printf("该方程有唯一的实根 x = %.2f\n", x1);
} else {
x1 = (-b + sqrt(delta)) / (2 * a);
x2 = (-b - sqrt(delta)) / (2 * a);
printf("该方程有两个实根 x1 = %.2f, x2 = %.2f\n", x1, x2);
}
return 0;
}
```
注意,由于使用了数学库中的 sqrt 函数,编译时需要链接 math 库,可以使用以下命令编译:
```bash
gcc -o main main.c -lm
```
用C语言计算一元二次方程a*x^2+b*x+c的根
在C语言中,我们可以使用公式法或者数值方法如牛顿迭代法来计算一元二次方程的解。这里我们选择最直接的方法——二次公式法,它适用于已知a、b和c系数的情况。二次方程的一般形式是ax² + bx + c = 0,其根可以通过下面的公式求得:
x = [ -b ± sqrt(b² - 4ac) ] / (2a)
如果b² - 4ac > 0,则有两个实数根;若b² - 4ac = 0,有一个实数根(重根);如果b² - 4ac < 0,则有两个复数根。
以下是C语言函数实现这个公式的示例:
```c
#include <stdio.h>
#include <math.h>
double calculateQuadraticRoots(double a, double b, double c) {
double discriminant = b * b - 4 * a * c;
if (discriminant >= 0) {
double root1 = (-b + sqrt(discriminant)) / (2 * a);
double root2 = (-b - sqrt(discriminant)) / (2 * a);
return (root1, root2); // 返回一个包含两个元素的数组
} else {
double realPart = -b / (2 * a);
double imaginaryPart = sqrt(-discriminant) / (2 * a);
return realPart, imaginaryPart; // 只有虚部,返回一个包含两个元素的数组
}
}
int main() {
double a, b, c;
printf("请输入一元二次方程的系数 a, b 和 c: ");
scanf("%lf %lf %lf", &a, &b, &c);
double roots[2];
roots = calculateQuadraticRoots(a, b, c);
if (roots[0] != REAL_NOT_A_NUMBER && roots[1] != REAL_NOT_A_NUMBER) { // 如果不是复数根
printf("根为: %.2lf 和 %.2lf\n", roots[0], roots[1]);
} else {
printf("根为: %.2lf + %.2fi 和 %.2lf - %.2fi\n", roots[0].real, roots[0].imaginary, roots[1].real, roots[1].imaginary);
}
return 0;
}
```
在这个程序中,用户会被提示输入三个系数,然后计算并打印出方程的根。
阅读全文