Java实现的求逆矩阵算法示例
作者:LazyChun 发布时间:2023-05-02 03:02:56
标签:Java,逆矩阵,算法
本文实例讲述了Java实现的求逆矩阵算法。分享给大家供大家参考,具体如下:
package demo;
public class MatrixInverse {
public static double Det(double [][]Matrix,int N)//计算n阶行列式(N=n-1)
{
int T0;
int T1;
int T2;
double Num;
int Cha;
double [][] B;
if(N>0)
{
Cha=0;
B=new double[N][N];
Num=0;
if(N==1)
{
return Matrix[0][0]*Matrix[1][1]-Matrix[0][1]*Matrix[1][0];
}
for (T0=0;T0<=N;T0++)//T0循环
{
for (T1=1;T1<=N;T1++)//T1循环
{
for (T2=0;T2<=N-1;T2++)//T2循环
{
if(T2==T0)
{
Cha=1;
}
B[T1-1][T2]=Matrix[T1][T2+Cha];
}
//T2循环
Cha=0;
}
//T1循环
Num=Num+Matrix[0][T0]*Det(B,N-1)*Math.pow((-1),T0);
}
//T0循环
return Num;
} else if(N==0)
{
return Matrix[0][0];
}
return 0;
}
public static double Inverse(double[][]Matrix,int N,double[][]MatrixC){
int T0;
int T1;
int T2;
int T3;
double [][]B;
double Num=0;
int Chay=0;
int Chax=0;
B=new double[N][N];
double add;
add=1/Det(Matrix,N);
for ( T0=0;T0<=N;T0++)
{
for (T3=0;T3<=N;T3++)
{
for (T1=0;T1<=N-1;T1++)
{
if(T1<T0)
{
Chax=0;
} else
{
Chax=1;
}
for (T2=0;T2<=N-1;T2++)
{
if(T2<T3)
{
Chay=0;
} else
{
Chay=1;
}
B[T1][T2]=Matrix[T1+Chax][T2+Chay];
}
//T2循环
}//T1循环
Det(B,N-1);
MatrixC[T3][T0]=Det(B,N-1)*add*(Math.pow(-1, T0+T3));
}
}
return 0;
}
public static void main(String[]args)//测试
{
double[][] TestMatrix = {
{1, 22, 34,22},
{1, 11,5,21} ,
{0,1,5,11},
{7,2,13,19}};
double[][]InMatrix=new double[4][4];
Inverse(TestMatrix,3,InMatrix);
String str=new String("");
for (int i=0;i<4;i++)
{
for (int j=0;j<4;j++)
{
String strr=String.valueOf(InMatrix[i][j]);
str+=strr;
str+=" ";
}
str+="\n";
}
System.out.println("脚本之家测试结果:");
System.out.println(str);
}
}
运行结果:
希望本文所述对大家java程序设计有所帮助。
来源:http://blog.csdn.net/u014581901/article/details/50805054


猜你喜欢
- 本文实例讲述了C#语音识别用法。分享给大家供大家参考。具体分析如下:C#可以利用微软操作系统自动的语音识别功能,读取信息。步骤如下:1.&n
- 一、概述UDP和TCP是网络通讯常用的两个传输协议,C#一般可以通过Socket来实现UDP和TCP通讯,由于.NET框架通过UdpClie
- 1、正常dubbo调用流程引入dubbo依赖引入他人提供的clinet依赖包;配置相同的注册中心,使用@Reference注解注入对应的se
- 一、length()返回此字符串的长度public static void main4(String[] args) { &n
- 说到关注功能,可能很多小伙伴要说了。谁不会写但是没有合理的架构,大家写出来的代码很可能是一大堆的复制粘贴。比如十几个页面,都有这个关注按钮。
- Mybatis mapper模糊查询语句LIKE最近做学校安排的课程设计作业,用到SSM框架,在自己写mapper代码是遇到了模糊查询的问题
- 由于工作和之前学习的原因,我需要同时使用Java和C#两门语言。这几年,我也一直在使用J2EE平台和.NET平台做开发。说起C#和Java这
- 这种情况,十有八九是SD存储卡的ext分区出错了,修复错误后重新开机即可重新启用a2sd+,找回原来安装的应用程序同修复FAT分区一样,这个
- hdfs上的文件是手动执行命令从本地linux上传至hdfs的。在真实的运行环境中,我们不可能每次手动执行命令上传的,这样太过繁琐。那么,我
- 前言BeanPostProcessor是一个工厂钩子,允许Spring框架在新创建Bean实例时对其进行定制化修改。例如:通过检查其标注的接
- 错误内容:com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis
- 如何在原有日期时间上加几个月或几天在原有的时间上添加几个月SimpleDateFormat df = new SimpleDateForma
- 做完一个Android项目之后,如何才能把项目发布到Internet上供别人使用呢?我们需要将自己的程序打包成Android安装包文件–AP
- 前言上一篇讲了普通轮询、加权轮询的两种实现方式,重点讲了平滑加权轮询算法,并在文末留下了悬念:节点出现分配失败时降低有效权重值;成功时提高有
- 先来看看效果:图片切分很多份,点击交换拼成一张完整的;这样关卡也很容易设计,3 3;4 4;5 5;6 6;一直下去加了个切换动画,效果还是
- 在Ubuntu Android简单介绍硬件抽象层(HAL)一文中,
- 多数据源创建数据库CREATE DATABASE mybatis_plus_1;USE mybatis_plus_1;CREATE TABL
- 步骤,如图所示:1.添加异步任务业务类package top.ytheng.demo.task;import java.util.concu
- 说起EventTrigger事件触发器,它的使用可以说是无处不在,EventTrigger继承了很多的事件接口,这些接口对我们开发是十分有用
- 在 Java 语言中,运算符有算数运算符、关系运算符、逻辑运算符、赋值运算符、字符串连接运算符、条件运算符。算数运算符算数运算符是我们最常用