c语言 求方程式ax2+bx+c=0的代码
时间: 2023-12-21 07:03:42 浏览: 66
以下是求解一元二次方程ax^2 + bx + c = 0的C语言代码:
```c
#include <stdio.h>
#include <math.h>
int main() {
double a, b, c, delta, x1, x2;
printf("请输入一元二次方程的系数(a, b, c):\n");
scanf("%lf %lf %lf",&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 = %.2lf, x2 = %.2lf\n", x1, x2);
} else if(delta == 0) {
x1 = x2 = -b / (2*a);
printf("方程有两个相等的实根:x1 = x2 = %.2lf\n", x1);
} else {
printf("方程没有实根\n");
}
return 0;
}
```
注:sqrt()函数需要在math.h库中引入。
相关问题
c语言解方程ax2+bx+c=0 a≠0
以下是一种用C语言解二次方程的方法:
```
#include <stdio.h>
#include <math.h>
int main() {
float a, b, c, delta, x1, x2;
printf("Enter a, b, c: ");
scanf("%f %f %f", &a, &b, &c);
delta = b * b - 4 * a * c;
if (delta < 0) {
printf("The equation has no real roots.\n");
} else if (delta == 0) {
x1 = x2 = -b / (2 * a);
printf("The equation has one real root: %.2f\n", x1);
} else {
x1 = (-b + sqrt(delta)) / (2 * a);
x2 = (-b - sqrt(delta)) / (2 * a);
printf("The equation has two real roots: %.2f and %.2f\n", x1, x2);
}
return 0;
}
```
在这个程序中,用户被要求输入三个浮点数a,b和c,分别代表二次方程的系数。然后,程序先计算delta,即判别式,根据delta的值判断方程的解的情况:
1. delta小于0,方程没有实数解。
2. delta等于0,方程有一个实数解,解为-x1=b/(2a)。
3. delta大于0,方程有两个实数解,解为x1=(-b+√delta)/(2a),x2=(-b-√delta)/(2a)。
最后输出方程的实数解。
请注意,如果你有特殊的要求或需要进一步验证,可能需要改进和修改上述程序。
用c语言求ax2+bx+c=0的根
可以使用以下公式求解二次方程的根:
delta = b * b - 4 * a * c;
if (delta > 0) {
root1 = (-b + sqrt(delta)) / (2 * a);
root2 = (-b - sqrt(delta)) / (2 * a);
} else if (delta == 0) {
root1 = root2 = -b / (2 * a);
} else {
printf("该方程没有实数根!");
}
其中,delta为方程的判别式,如果大于0,则存在两个实数根;等于0,则存在一个实数根;小于0,则不存在实数根。