求解一元二次方程ax*x+bx+c=0的实数解,写出代码
时间: 2023-12-23 18:05:23 浏览: 36
Python代码:
import math
def solve_quadratic_equation(a, b, c):
delta = b * b - 4 * a * c
if delta < 0:
return None
elif delta == 0:
return -b / (2 * a)
else:
x1 = (-b + math.sqrt(delta)) / (2 * a)
x2 = (-b - math.sqrt(delta)) / (2 * a)
return x1, x2
a = float(input("请输入a的值:"))
b = float(input("请输入b的值:"))
c = float(input("请输入c的值:"))
result = solve_quadratic_equation(a, b, c)
if result is None:
print("该方程无实数解")
elif isinstance(result, float):
print("该方程有一个实数解:{}".format(result))
else:
print("该方程有两个实数解:{}和{}".format(result[0], result[1]))
相关问题
求解一元二次方程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;
}
```
编写求解一元二次方程ax方+bx+c=0的根的过程
以下是求解一元二次方程的 Python 代码:
```python
import math
def quadratic_equation(a, b, c):
"""
求解一元二次方程 ax^2 + bx + c = 0 的根
返回值为一个元组,包含两个根或一个根或 None
"""
delta = b ** 2 - 4 * a * c
if delta > 0:
x1 = (-b + math.sqrt(delta)) / (2 * a)
x2 = (-b - math.sqrt(delta)) / (2 * a)
return x1, x2
elif delta == 0:
x = -b / (2 * a)
return x,
else:
return None
# 测试
print(quadratic_equation(1, -5, 6)) # (3.0, 2.0)
print(quadratic_equation(1, -4, 4)) # (2.0,)
print(quadratic_equation(1, 2, 3)) # None
```
其中,`quadratic_equation()` 函数接受三个参数,分别是方程中 $x^2$ 的系数 $a$、$x$ 的系数 $b$ 和常数 $c$。函数先根据判别式 $\Delta = b^2 - 4ac$ 的值来判断方程的根的情况,如果 $\Delta > 0$,则有两个不相等的实数根;如果 $\Delta = 0$,则有一个实数根;如果 $\Delta < 0$,则无实数根。如果有实数根,函数返回一个元组,包含两个根或一个根;如果无实数根,则返回 None。