115.n阶方阵求逆

简介: 115.n阶方阵求逆
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define MAX 255
void MatrixMul(a,b,m,n,k,c)  /*实矩阵相乘*/
int m,n,k; /*m:矩阵A的行数, n:矩阵B的行数, k:矩阵B的列数*/
double a[],b[],c[]; /*a为A矩阵, b为B矩阵, c为结果,即c = AB */
{
  int i,j,l,u;
  /*逐行逐列计算乘积*/
  for (i=0; i<=m-1; i++)
    for (j=0; j<=k-1; j++)
    {
      u=i*k+j; c[u]=0.0;
      for (l=0; l<=n-1; l++)
        c[u]=c[u]+a[i*n+l]*b[l*k+j];
    }
    return;
}
int brinv(a,n) /*求矩阵的逆矩阵*/
int n; /*矩阵的阶数*/
double a[]; /*矩阵A*/
{
  int *is,*js,i,j,k,l,u,v;
    double d,p;
    is=malloc(n*sizeof(int));
    js=malloc(n*sizeof(int));
    for (k=0; k<=n-1; k++)
  {
    d=0.0;
    for (i=k; i<=n-1; i++)
      /*全选主元,即选取绝对值最大的元素*/
      for (j=k; j<=n-1; j++)
      {
        l=i*n+j; p=fabs(a[l]);
        if (p>d) { d=p; is[k]=i; js[k]=j;}
      }
    /*全部为0,此时为奇异矩阵*/
    if (d+1.0==1.0)
    {
      free(is); free(js); printf(" >> This is a singular matrix, can't be inversed!\n");
      return(0);
    }
    /*行交换*/
    if (is[k]!=k)
      for (j=0; j<=n-1; j++)
      {
        u=k*n+j; v=is[k]*n+j;
        p=a[u]; a[u]=a[v]; a[v]=p;
      }
    /*列交换*/
    if (js[k]!=k)
      for (i=0; i<=n-1; i++)
      {
        u=i*n+k; v=i*n+js[k];
        p=a[u]; a[u]=a[v]; a[v]=p;
      }
    l=k*n+k;
    a[l]=1.0/a[l]; /*求主元的倒数*/
    /* a[kj]a[kk] -> a[kj] */
    for (j=0; j<=n-1; j++)
      if (j!=k)
      {
        u=k*n+j; a[u]=a[u]*a[l];
      }
    /* a[ij] - a[ik]a[kj] -> a[ij] */
    for (i=0; i<=n-1; i++)
      if (i!=k)
        for (j=0; j<=n-1; j++)
          if (j!=k)
          {
            u=i*n+j;
            a[u]=a[u]-a[i*n+k]*a[k*n+j];
          }
    /* -a[ik]a[kk] -> a[ik] */
    for (i=0; i<=n-1; i++)
      if (i!=k)
      {
        u=i*n+k; a[u]=-a[u]*a[l];
      }
  }
    for (k=n-1; k>=0; k--)
  {
    /*恢复列*/
    if (js[k]!=k)
      for (j=0; j<=n-1; j++)
      {
        u=k*n+j; v=js[k]*n+j;
        p=a[u]; a[u]=a[v]; a[v]=p;
      }
      /*恢复行*/
    if (is[k]!=k)
      for (i=0; i<=n-1; i++)
      {
        u=i*n+k; v=i*n+is[k];
        p=a[u]; a[u]=a[v]; a[v]=p;
      }
  }
    free(is); free(js);
    return(1);
}
print_matrix(a,n)/*打印的方阵a的元素*/
int n; /*矩阵的阶数*/
double a[]; /*矩阵a*/
{
  int i,j;
  for (i=0; i<n; i++)
  {
    for (j=0; j<n; j++)
      printf("%13.7f\t",a[i*n+j]);
    printf("\n");
  }
}
main()
{
  int i,j,n=0;
  double A[MAX],B[MAX],C[MAX];
    static double a[4][4]={ {0.2368,0.2471,0.2568,1.2671},
  {1.1161,0.1254,0.1397,0.1490},
  {0.1582,1.1675,0.1768,0.1871},
  {0.1968,0.2071,1.2168,0.2271}};
    static double b[4][4],c[4][4];
    clrscr();
    puts("**********************************************************");
    puts("*    This program is to inverse a square matrix A(nxn).  *");
    puts("**********************************************************");
    while(n<=0)
    {
      printf(" >> Please input the order n of the matrix (n>0): ");
      scanf("%d",&n);
    }
    printf(" >> Please input the elements of the matrix one by one:\n >> ");
    for(i=0;i<n*n;i++)
    {
      scanf("%lf",&A[i]);
      B[i]=A[i];
    }
    for(i=0;i<4;i++)
  for(j=0;j<4;j++)
    b[i][j]=a[i][j];
    i=brinv(A,n);
    if (i!=0)
    {
  printf("    Matrix A:\n");
  print_matrix(B,n);
  printf("\n");
  printf("    A's Inverse Matrix A-:\n");
  print_matrix(A,n);
  printf("\n");
  printf("    Product of A and A- :\n");
  MatrixMul(B,A,n,n,n,C);
  print_matrix(C,n);
    }
    printf("\n Press any key to quit...");
    getch();
}
相关文章
|
8月前
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
329 77
|
10月前
|
机器学习/深度学习 人工智能 TensorFlow
基于TensorFlow的深度学习模型训练与优化实战
基于TensorFlow的深度学习模型训练与优化实战
444 3
|
10月前
|
Java 数据库连接 数据库
如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面
本文介绍了如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面。通过合理配置初始连接数、最大连接数和空闲连接超时时间,确保系统性能和稳定性。文章还探讨了同步阻塞、异步回调和信号量等并发控制策略,并提供了异常处理的最佳实践。最后,给出了一个简单的连接池示例代码,并推荐使用成熟的连接池框架(如HikariCP、C3P0)以简化开发。
266 2
|
Ubuntu 关系型数据库 MySQL
使用PXD工具一键安装PolarDB-X的体验
这次体验挺有意思的,对PolarDB-X有了更深入的了解,也希望能通过这些建议帮助产品做得更好。
582 2
使用PXD工具一键安装PolarDB-X的体验
|
Java Linux Arthas
linux上如何排查JVM内存过高?
linux上如何排查JVM内存过高?
1224 0
|
Python
Python3,使用openpyxl进行excel数据对比,反手一个赞。
Python3,使用openpyxl进行excel数据对比,反手一个赞。
227 0
|
编解码 Android开发
|
算法 JavaScript Java
hutool hash工具
hutool hash工具
|
移动开发 运维 Cloud Native
免费下载|《云原生时代下的App开发》走进阿里云一站式应用研发平台EMAS
作为国内移动互联网、云计算领域的行业巨擘,阿里巴巴在大前端、云原生领域有着丰富的实战经验。阿里技术人从2016年开始逐步将阿里集团内部成熟的应用中间件云化输出,并在2018年推出了移动研发平台EMAS。
免费下载|《云原生时代下的App开发》走进阿里云一站式应用研发平台EMAS