Python· 求解一元二次方程实根的函数

在Python中,求解一元二次方程 ( ax^2 + bx + c = 0 ) 的实根可以通过使用math模块中的sqrt函数来实现。这里提供一个简单的函数,它接受三个参数abc,然后返回方程的实根。

python 复制代码
import math

def solve_quadratic(a, b, c):
    # 计算判别式的值
    discriminant = b**2 - 4*a*c
    
    # 检查判别式的值
    if discriminant < 0:
        return None  # 没有实数解
    elif discriminant == 0:
        # 一个实数解
        return -b / (2 * a)
    else:
        # 两个实数解
        root1 = (-b + math.sqrt(discriminant)) / (2 * a)
        root2 = (-b - math.sqrt(discriminant)) / (2 * a)
        return root1, root2

# 使用函数
a = 1
b = -3
c = 2
roots = solve_quadratic(a, b, c)
if roots is None:
    print("No real roots.")
else:
    if isinstance(roots, tuple):
        print(f"The roots are {roots[0]} and {roots[1]}.")
    else:
        print(f"The root is {roots}.")

这个函数首先计算判别式Δ = b^2 - 4ac。根据判别式的值,可以确定方程的根:

  • 如果判别式小于0,方程没有实数解。
  • 如果判别式等于0,方程有一个实数解(重根)。
  • 如果判别式大于0,方程有两个不同的实数解。

请注意,这个函数返回的是一个实数或者一个包含两个实数的元组。如果方程没有实数解,函数返回None

相关推荐
CoovallyAIHub11 分钟前
CVPR 2026 | GS-CLIP:3D几何先验+双流视觉融合,零样本工业缺陷检测新SOTA,四大3D工业数据集全面领先!
深度学习·算法·计算机视觉
有意义3 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
用户726876103374 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect4 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
明月_清风6 小时前
Python 装饰器前传:如果不懂“闭包”,你只是在复刻代码
后端·python
明月_清风6 小时前
打破“死亡环联”:深挖 Python 分代回收与垃圾回收(GC)机制
后端·python
ZhengEnCi1 天前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记1 天前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan1 天前
AI小镇 - 涌现
算法·架构
AI工程架构师1 天前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法