首页 > 编程语言 > 详细

(转)Python的“黑暗魔法”,两行解一元一次方程

时间:2016-04-16 10:42:16      阅读:283      评论:0      收藏:0      [点我收藏+]

无意看到一个大神写的《Linear equations solver in 3 lines (Python recipe)》,Python解一元一次方程只需要三行就完成了,确实很强悍啊。

我们来围观一下:
技术分享

说到底呢,这个段代码的关键是利用了复数。
第一步:
2 * x + 233 = x * 8 + 3
变成
2 * x + 233 -(x * 8 + 3)
然后把x变成虚数1j
然后变成
2 * 1j + 233 -(1j * 8 + 3)
通过eval算出结果为230-6j
因为我们知道这个表达式结果为0,而且j也相当于x。
所以问题变成了:230-6j=0,也就是230-6x=0。
最后x = - 230 / 6 = 38.33333333336。

 

这里的核心是用到了Python的黑暗魔法eval,eval的第一个参数是表达式,第二个参数是命名空间,也就是把 x = 1j 通过第二个参数把一些值放进去。

技术分享

神奇的求解函数:

 

def s(eq, var=‘x‘):
    r = eval(eq.replace(‘=‘, ‘-(‘) + ‘)‘, {var:1j})
    return -r.real / r.imag

 

本文链接:http://everet.org/2012/04/linear-equations-solvers-in-python.html
(转载时请注明作者和出处。)

 

(转)Python的“黑暗魔法”,两行解一元一次方程

原文:http://www.cnblogs.com/cheer-wang/p/2817886.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!