【基础入门题025】求二次方程的根

简介: 【基础入门题025】求二次方程的根

【基础入门题】2021.11.21


求一元二次方程ax²+bx+c=0的根,设计二次方程求根函数root(a,b,c)

返回值:[x1]或[x1,x1]或[x1,x2],如是实数范围允许返回[]表示无实数根。


编程语言:包括但不限于Python

题目来源:派森特给站每日刷题频道


方法一:求根公式,有无理数根时计算为近似的浮点数。



def roots(a,b,c):
  assert(a!=0)
  delta = b**2-4*a*c
  if delta<0:
    return []
  elif delta==0:
    return [-b/(2*a)]
  else:
    return [-(b-delta**0.5)/(2*a),-(b+delta**0.5)/(2*a)]



方法二:在复数范围内求根,python自带复数类型

def roots(a,b,c):
  assert(a!=0)
  delta = b**2-4*a*c
  return [-(b-delta**0.5)/(2*a),-(b+delta**0.5)/(2*a)]
print( roots(1,-2,2) )
# 输出: [(1+1j), (0.9999999999999999-1j)]
# j 为虚数单位
print( roots(1,-2,1) )
# 输出: [1.0, 1.0]
# 表示两个相同实数根


方法三: 用sympy库求方程的根,可以保留无理数根,甚至是复数根。

def roots(a,b,c):
    assert(a!=0)
  import sympy
  x = sympy.symbols('x')
  return sympy.solve(a*x**2+b*x+c,x)
>>> roots(1,2,1)
[-1]
>>> roots(1,2,-3)
[-3, 1]
>>> roots(1,-2,-1)
[1 - sqrt(2), 1 + sqrt(2)]
>>> roots(1,-2,2)
[1 - I, 1 + I]
>>> roots(1,-2,3)
[1 - sqrt(2)*I, 1 + sqrt(2)*I]
>>> # I 为虚数单位



方法四: 类方法

class Root():
    def __init__(self,a, b, c):
        self.a = a
        self.b = b
        self.c = c
    def getDiscriminant(self):
        return self.b**2-4*self.a*self.c
    def getRoot(self):
        if self.getDiscriminant()<0: return []
        if self.getDiscriminant()==0: return [-self.b/self.a/2]
        return [(-self.b-self.getDiscriminant()**0.5)/self.a/2,
                (-self.b+self.getDiscriminant()**0.5)/self.a/2]
a,b,c = list(map(float,input().split()))
r = Root(a, b, c)
print(r.getRoot())
目录
相关文章
|
7月前
|
JavaScript BI
技术笔记:JS获取子节点、父节点和兄弟节点的方法实例总结
技术笔记:JS获取子节点、父节点和兄弟节点的方法实例总结
128 0
|
8月前
|
存储 Android开发 算法
Android技能树 — 数组,链表,散列表基础小结,android教程零基础入门
Android技能树 — 数组,链表,散列表基础小结,android教程零基础入门
|
8月前
|
前端开发
【零基础入门前端系列】—关系选择器(十一)
【零基础入门前端系列】—关系选择器(十一)
|
8月前
|
前端开发
【零基础入门前端系列】—属性选择器和定位(二十)
【零基础入门前端系列】—属性选择器和定位(二十)
|
8月前
|
存储 算法
【408数据结构与算法】—树和二叉树(二十七)
【408数据结构与算法】—树和二叉树(二十七)
|
8月前
|
前端开发
【零基础入门前端系列】—浮动(十八)
【零基础入门前端系列】—浮动(十八)
|
8月前
|
前端开发
【零基础入门前端系列】—伪对象选择器(十七)
【零基础入门前端系列】—伪对象选择器(十七)
|
前端开发
CSS基础入门笔记(选择器)(上)
CSS基础入门笔记(选择器)(上)
100 0
CSS基础入门笔记(选择器)(上)
|
Python
【基础入门题002】质因数的个数
【基础入门题002】质因数的个数
71 0
|
存储 算法
数据结构与算法(十三)B+树
数据结构与算法(十三)B+树
61 0