5272: 逆矩阵 

Time Limit(Common/Java):1000MS/3000MS     Memory Limit:65536KByte
Total Submit: 11            Accepted:7

Description

设A是数域上的一个n阶方阵,若在相同数域上存在另一个n阶矩阵B,使得:AB=BA=E(单位矩阵)。 则我们称B是A的逆矩阵,而A则被称为可逆矩阵。

现在告诉你一个n阶方阵A,求它的逆矩阵B。

Input

输入数据有多组,第一行为数据组数T,接下来有T个矩阵。

每个矩阵的第一行为n(n<20),表示n阶方阵,接下来的n行n列表示n*n的矩阵

矩阵元素为实数。

Output

按照n行n列输出逆矩阵B,所有元素保留2位小数。数据保证一定有逆矩阵。

Sample Input

1
5
1.3 0.8 0.5 0.8 1.0
0.5 0.6 1.0 1.3 1.0
0.8 1.4 0.9 1.1 1.4
1.0 0.6 0.8 1.4 0.5
0.7 0.6 1.4 1.4 1.2

Sample Output

0.86 -1.37 -0.36 0.37 0.69
-1.10 -1.90 1.71 0.93 0.12
-1.08 -4.01 0.72 0.64 3.14
0.01 3.06 -0.61 0.33 -1.99
1.29 2.85 -0.77 -1.81 -0.97

Source

矩阵的逆,我提供了两种方法。

LU分解

#include<stdio.h>
const int N=;
double a[N][N],b[N][N],c[N][N],bt[N][N],ct[N][N],ans[N][N];
int T,n;
void LU()
{
for(int i=; i<n; i++)
for(int j=; j<n; j++)b[i][j]=c[i][j]=bt[i][j]=ct[i][j]=ans[i][j]=;
for(int i=; i<n; i++)b[i][i]=bt[i][i]=;
double s;
for(int i=; i<n; i++)
{
for(int j=i; j<n; j++)
{
s=;
for(int k=; k<i; k++)
s+=b[i][k]*c[k][j];
c[i][j]=a[i][j]-s;
}
for(int j=i+; j<n; j++)
{
s=;
for(int k=; k<i; k++)
s+=b[j][k]*c[k][i];
b[j][i]=(a[j][i]-s)/c[i][i];
}
}
for(int i=; i<n; i++)
for(int j=; j<i; j++)
{
s=;
for(int k=; k<i; k++)
s+=b[i][k]*bt[k][j];
bt[i][j]=-s;
}
for(int i=; i<n; i++)
ct[i][i]=/c[i][i];
for(int i=; i<n; i++)
for(int j=i-; j>=; j--)
{
s=;
for(int k=j+; k<=i; k++)
s+=c[j][k]*ct[k][i];
ct[j][i]=-s/c[j][j];
}
for(int i=; i<n; i++)
for(int j=; j<n; j++)
for(int k=; k<n; k++)
ans[i][j]+=ct[i][k]*bt[k][j];
for(int i=; i<n; i++)
for(int j=; j<n; j++)printf("%.2f%c",ans[i][j],j==n-?'\n':' ');
}
int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=; i<n; i++)
for(int j=; j<n; j++)
scanf("%lf",&a[i][j]);
LU();
}
return ;
}

Gauss 消元

#include<stdio.h>
#include<math.h>
#include<algorithm>
const double eps=1e-;
const int N=;
double a[N][N],b[N],x[N],s,t[N][N],ans[N][N];
int n;
void gauss()
{
int i;
for(int k=; k<=n; k++)
{
for(i=k; i<=n&&fabs(a[i][k])<eps; i++);
if(i!=k)
{
for(int j=k; j<=n; j++)std::swap(a[i][j],a[k][j]);
std::swap(b[i],b[k]);
}
for(i=k+; i<=n; i++)
{
s=a[i][k]/a[k][k];
for(int j=k; j<=n; j++)a[i][j]-=a[k][j]*s;
b[i]-=b[k]*s;
}
}
for(i=n; i>=; --i)
{
s=b[i];
for(int j=i+; j<=n; j++)s-=x[j]*a[i][j];
x[i]=s/a[i][i];
if(fabs(x[i])<eps)x[i]=;
}
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=; i<=n; i++)
{
for(int j=; j<=n; j++)
scanf("%lf",&t[i][j]),a[i][j]=t[i][j];
b[i]=;
}
for(int k=; k<=n; k++)
{
for(int i=; i<=n; i++)
{
for(int j=; j<=n; j++)a[i][j]=t[i][j];
b[i]=;
}
b[k]=;
gauss();
for(int i=; i<=n; i++)ans[i][k]=x[i];
}
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)printf("%.2f%c",ans[i][j],j==n?'\n':' ');
}
return ;
}

TOJ5272: 逆矩阵的更多相关文章

  1. c++实现矩阵类矩阵行列式,伴随矩阵,逆矩阵

    //Matrix ver1.0 //只支持矩阵内部(方阵)的运算 #include<iostream> #include<math.h> using namespace std ...

  2. BZOJ 3640 JC的小苹果(逆矩阵)

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3640 题意:给出一个无向图,从1走到n.开始是血量H,从u到达v时血量减少a[v] ...

  3. 《Linear Algebra and Its Applications》-chaper3-行列式-从一个逆矩阵算法证明引入的行列式

    这一章节开始介绍线性代数中另外一个基本概念——行列式. 其实与矩阵类似,行列式也是作为简化表述多项式的一种工具,关于行列式的历史渊源,有如下的介绍. 在介绍逆矩阵的时候,我们曾提及二阶矩阵有一个基于矩 ...

  4. 学习笔记DL004:标量、向量、矩阵、张量,矩阵、向量相乘,单位矩阵、逆矩阵

    线性代数,面向连续数学,非离散数学.<The Matrix Cookbook>,Petersen and Pedersen,2006.Shilov(1977). 标量.向量.矩阵.张量. ...

  5. 浅谈范德蒙德(Vandermonde)方阵的逆矩阵的求法以及快速傅里叶变换(FFT)中IDFT的原理

    浅谈范德蒙德(Vandermonde)方阵的逆矩阵与拉格朗日(Lagrange)插值的关系以及快速傅里叶变换(FFT)中IDFT的原理 标签: 行列式 矩阵 线性代数 FFT 拉格朗日插值 只要稍微看 ...

  6. 使用cv::invert()求解Mat矩阵的逆矩阵

    opencv中cv::invert()可直接用来求解矩阵的逆矩阵 函数原型如下: double cv::invert(InputArray  src, OutputArray dst, int  fl ...

  7. matlab中求逆矩阵的高斯消元法实现的代码

    function qiuni =INV_GET(a)N=length(a);M=eye(N);%得到上三角矩?for i=1:N max=a(i,i); A=i; for j=i+1:N if(abs ...

  8. 求伪逆矩阵c++代码(Eigen库)

    非方阵的矩阵的逆矩阵  pseudoInverse 伪逆矩阵是逆矩阵的广义形式,广义逆矩阵 matlab中是pinv(A)-->inv(A). #include "stdafx.h&q ...

  9. 使用lapack图书馆逆矩阵

    阿土,直接在代码: #include <string> #include "lapacke.h" #include "lapack_aux.h" i ...

随机推荐

  1. hihoCoder hiho一下 第十二周 #1055 : 刷油漆 (树上DP)

    思路: 只能刷部分节点数m,总节点数n.如果m>=n那么就可以全刷了,那就不用任何算法了.如果m<n那么就要有取舍了.用DP思路,记录下每个节点如果获得到1~m个选择所能获得的最大权值.这 ...

  2. 平时对ES6的一些总结

    1.Genertor中yield和Interator中的next方法 Genertor的yield是把这个函数变成分段的:Interator中的next也是一个一个执行的: function* f() ...

  3. SAP成都研究院CEC团队三巨头之一:M君的文章预告

    国人总倾向于把特点或者作用类似的人或物放在一起比较并做出排名,于是就有了许多"某某某三巨头"的称谓. 最举世闻名的莫过于二战三巨头:丘吉尔,罗斯福和斯大林. 还有陪伴咱八零后童年时 ...

  4. 这些年,在wp平台打拼的日子

    最近经常胃疼,在当地的镇医院看了几次都没有改善,只好去市医院照胃镜检查,发现有胃炎,虽然是很普通和常见的毛病,但这种毛病一但沾上,就很难根治,一喝酒或者吃饭不定时.熬夜.吃酸辣冷冻等食物都容易引起复发 ...

  5. Linux系统运维常见面试简答题(36题)

    1.请描述下linux 系统的开机启动过程开机加电BIOS自检———–>MBR引导———–>grub引导菜单———–>加载内核———–>启动init进程———–>读取in ...

  6. 用virtualenv构建一个新的python环境,这个新的环境在这个创建的文件夹下

    http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143271210830032 ...

  7. dubbo + zookeeper 配置

      Dubbo与Zookeeper.SpringMVC整合和使用 windows环境介绍: myeclipse 10 jdk1.6 tomcat 6.0.35 一.安装Zookeeper 1.通过链接 ...

  8. 闭包 -------JavaScript

    本文摘要:http://www.liaoxuefeng.com/ 函数作为返回值 高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回. 我们来实现一个对Array的求和.通常情况下,求和的 ...

  9. java链接MySQL数据库时使用com.mysql.jdbc.Connection的包会出红线问题 java.lang.ClassNotFoundException: com.mysql.jdbc.Driver问题

    package com.swift; //这里导入的包是java.sql.Connection而不是com.mysql.jdbc.Connection import java.sql.Connecti ...

  10. V8引擎——详解

    前言 JavaScript绝对是最火的编程语言之一,一直具有很大的用户群,随着在服务端的使用(NodeJs),更是爆发了极强的生命力.编程语言分为编译型语言和解释型语言两类,编译型语言在执行之前要先进 ...