怎么用c语言一元二次方程求解,ax^2+bx+c=0. d=b^2-4ac.
时间: 2023-07-16 18:17:25 浏览: 53
你可以使用以下代码来求解一元二次方程:
```c
#include <stdio.h>
#include <math.h>
int main() {
double a, b, c, d, x1, x2;
printf("Enter coefficients a, b and c: ");
scanf("%lf %lf %lf", &a, &b, &c);
d = b * b - 4 * a * c;
if (d < 0) {
printf("Roots are complex numbers.\n");
}
else {
x1 = (-b + sqrt(d)) / (2 * a);
x2 = (-b - sqrt(d)) / (2 * a);
printf("Roots are: %.2lf and %.2lf\n", x1, x2);
}
return 0;
}
```
在这个代码中,我们使用 `scanf` 从用户输入获取系数 `a`、`b` 和 `c`,然后计算判别式 `d`。如果 `d` 的值小于 `0`,则说明根是复数;否则,我们使用 `sqrt` 函数计算根。最后,我们使用 `printf` 打印出根的值。
相关问题
C语言编程求一元二次方程ax平方+bx+c=0的实根
A:一元二次方程ax^2 + bx + c = 0的实根可以通过以下公式求解:
x = (-b ± √(b^2 - 4ac)) / (2a)
其中,a、b、c分别为方程的系数。要求实根,则需要判断判别式D是否大于等于0:
D = b^2 - 4ac
若D大于等于0,则方程有实根;若D小于0,则方程没有实根。
以下是C语言的代码示例:
```c
#include <stdio.h>
#include <math.h> // 需要包含数学函数库
int main() {
float a, b, c, x1, x2, delta;
printf("请输入方程的系数:\n");
scanf("%f%f%f", &a, &b, &c); // 输入系数
delta = b * b - 4 * a * c; // 求解判别式
if (delta >= 0) { // 判断是否有实根
x1 = (-b + sqrt(delta)) / (2 * a); // 求解第一个根
x2 = (-b - sqrt(delta)) / (2 * a); // 求解第二个根
printf("方程的实根为:x1 = %f,x2 = %f\n", x1, x2);
} else {
printf("方程没有实根!\n");
}
return 0;
}
```
求解一元二次方程ax*x+bx+c=0的实数解,c语言代码
```
#include <stdio.h>
#include <math.h>
int main() {
float a, b, c;
float delta, x1, x2;
printf("请输入a、b、c的值:\n");
scanf("%f %f %f", &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 = %.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;
}
```