【基础入门题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())


 欢迎加入csdn社区!https://bbs.csdn.net/forums/PythonTogetherhttps://bbs.csdn.net/forums/PythonTogether

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hann Yang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值