一元二次方程c语言代码
时间: 2023-05-21 14:04:52 浏览: 55
以下是一元二次方程的 C 代码:
```c
#include <stdio.h>
#include <math.h>
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 = root2 = -b / (2 * a);
printf("根为 %.2lf 和 %.2lf\n", root1, root2);
} else {
printf("根为虚数\n");
}
return 0;
}
```
请注意,这只是一个简单的例子,仅仅是为了演示一元二次方程的求解方法,还有许多需要改进的地方,比如可能需要增加错误检查等。
相关问题
求解一元二次方程c语言
以下是一个求解一元二次方程的C语言小程序,按照标准形式输入方程所需参数即可得到方程的解:
```c
#include <stdio.h>
#include <math.h>
int main()
{
double a, b, c, delta, x1, x2, realPart, imagPart;
printf("请输入一元二次方程的系数:\n");
printf("a = ");
scanf("%lf", &a);
printf("b = ");
scanf("%lf", &b);
printf("c = ");
scanf("%lf", &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
{
realPart = -b / (2 * a);
imagPart = sqrt(-delta) / (2 * a);
printf("方程无解:x1 = %.2lf + %.2lfi, x2 = %.2lf - %.2lfi\n", realPart, imagPart, realPart, imagPart);
}
return 0;
}
```
求解一元二次方程的C语言代码
以下是求解一元二次方程的C语言代码:
```c
#include <stdio.h>
#include <math.h>
int main() {
float a, b, c, delta, x1, x2;
printf("请输入一元二次方程的系数:\n");
printf("a = ");
scanf("%f", &a);
printf("b = ");
scanf("%f", &b);
printf("c = ");
scanf("%f", &c);
delta = b * b - 4 * a * c;
if (delta > 0) {
x1 = (-b + sqrt(delta)) / (2 * a);
x2 = (-b - sqrt(delta)) / (2 * a);
printf("方程有两个不相等的实根:x1 = %.2f, x2 = %.2f\n", x1, x2);
} else if (delta == 0) {
x1 = -b / (2 * a);
printf("方程有两个相等的实根:x1 = x2 = %.2f\n", x1);
} else {
printf("方程没有实根!\n");
}
return 0;
}
```