高分求一道C语言程序设计,要求用到函数·选择分支,数组~~~急求,谢谢!!!

来源:百度知道 编辑:UC知道 时间:2024/05/17 07:41:01
谢谢各位大哥大姐了,我就这么多分,全部奉上了~~~~~

求矩阵的逆矩阵~~~~函数·选择分支,数组~~~都用上了
#include <stdlib.h>
#include <math.h>
#include <stdio.h>

double *inv(double *a,int n)
{
int *is,*js,i,j,k,l,u,v;
double d,p;
is=(int*)malloc(n*sizeof(int));
js=(int*)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;}
}
if (d+1.0==1.0)
{ free(is); free(js); printf("err**not inv\n");
return NULL;
}
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];