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

相关推荐
weixin_580614005 小时前
如何提取SQL日期中的年份_使用YEAR或EXTRACT函数
jvm·数据库·python
2301_813599555 小时前
SQL生产环境规范_数据库使用最佳实践
jvm·数据库·python
李可以量化5 小时前
QMT 量化实战:用 Python 实现线性回归通道,精准识别趋势中的支撑与压力(下)
python·qmt·量化 qmt ptrade
a9511416425 小时前
Go 中通过 channel 传递切片时的数据竞争与深拷贝解决方案
jvm·数据库·python
Dxy12393102165 小时前
Python 使用正则表达式将多个空格替换为一个空格
开发语言·python·正则表达式
qq_189807035 小时前
如何修改RAC数据库名_NID工具在集群环境下的改名步骤
jvm·数据库·python
zhangchaoxies6 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
Luca_kill6 小时前
MCP数据采集革命:从传统爬虫到智能代理的技术进化
爬虫·python·ai·数据采集·mcp·webscraping·集蜂云
zhangchaoxies6 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
故事和你917 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论