问题:求解四元一次方程,例如
x+y-z=9;
x-y+2z=8;
2x+y-z=7;
x+y+z=m;
这个解是 x=-2.0 y=32.0 z=21.0 m=51.0
如果你想利用迭代暴力计算的话,不用试了,我替你试过了,太慢,慢的一天你也解不出来,比如x,y,z,m的范围是从-2.0到51.0
那么解决不了了吗?这时脑海中依稀想起来了大学学过线性代数,于是乎找美丽的度娘亲热了大半个下午,终于把线性代数部分知识拾起来了点 o(╯□╰)o
顺便也帮大家温习下,先来个入门简单的
PS:或许好多客官认为这个温习没必要,傻逼才看呢,可是我想说,等你想拓展这个程序,想要解5元一次方程,n元一次方程的时候,你绝对用得着。但是如果你精通高数,线性代数的话,算我没说。。。
然后再看下克拉默法则:
然后再看看代数余子式:
汗,最后步入正题,代码就简单了,其实就是套公式,看代码吧。。。
(注意要解的方程组把变量都放到左边,常亮放到右边,然后再写strss这个二维数组)
/**
* 解四元一次方程
* @author liuyj
*/
public class ArithmeticOfCalcFour {
public static void main(String[] args) {