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

相关推荐
学测绘的小杨19 分钟前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
用户9385156350734 分钟前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC2 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥2 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者4 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者4 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月7 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
zzzzzz3107 小时前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐7 小时前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
小月土星8 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试