|
1章 线性代数方程组的求解 1.1 [全选主元]高斯消去法 例:求解4阶方程组 ------------------------------------------------------- /* AGAUS0.c */ 主函数,调用AGAUS.c中的agaus(a,b,n)函数 ------------------------------------------------------- #include "stdio.h" #include "agaus.c" main() { int i; static double a[4][4]= { {0.2368,0.2471,0.2568,1.2671}, {0.1968,0.2071,1.2168,0.2271}, {0.1581,1.1675,0.1768,0.1871}, {1.1161,0.1254,0.1397,0.1490} }; static double b[4]={1.8471,1.7471,1.6471,1.5471}; if (agaus(a,b,4)!=0) for (i=0;i<=3;i++) printf("x(%d)=%e\n",i,b[i]); } /*****************************************************/ ------------------------------------------------------- /* AGAUS.c */ 本函数返回一个整型标志位。 若返回的标志位为0,则表示原方程组的系数矩阵奇异,输出 信息"fail"; 若返回的标志位不为0,则表示正常返回。 其中a为双精度实型二维数组,为n*n。存放方程组的系数矩阵, 返回时将被破坏。 b为双精度实型一维数组,长度为n。存放方程组右端的常数 向量;返回方程组的解向量。 n为整型变量。存放方程组的阶数。 ------------------------------------------------------- #include "stdlib.h" #include "math.h" #include "stdio.h" int agaus(a,b,n) int n; double a[],b[]; { int *js,l,k,i,j,is,p,q; double d,t; js=malloc(n*sizeof(int)); l=1; for (k=0;k<=n-2;k++) { d=0.0; for (i=k;i<=n-1;i++) for (j=k;j<=n-1;j++) { t=fabs(a[i*n+j]); if (t>d) { d=t; js[k]=j; is=i;} } if (d+1.0==1.0) l=0; else { if (js[k]!=k) for (i=0;i<=n-1;i++) { p=i*n+k; q=i*n+js[k]; t=a[p]; a[p]=a[q]; a[q]=t; } if (is!=k) { for (j=k;j<=n-1;j++) { p=k*n+j; q=is*n+j; t=a[p]; a[p]=a[q]; a[q]=t; } t=b[k]; b[k]=b[is]; b[is]=t; } } if (l==0) { free(js); printf("fail\n"); return(0); } d=a[k*n+k]; for (j=k+1;j<=n-1;j++) { p=k*n+j; a[p]=a[p]/d;} b[k]=b[k]/d; for (i=k+1;i<=n-1;i++) { for (j=k+1;j<=n-1;j++) { p=i*n+j; a[p]=a[p]-a[i*n+k]*a[k*n+j]; } b[i]=b[i]-a[i*n+k]*b[k]; } } d=a[(n-1)*n+n-1]; if (fabs(d)+1.0==1.0) { free(js); printf("fail\n"); return(0); } b[n-1]=b[n-1]/d; for (i=n-2;i>=0;i--) { t=0.0; for (j=i+1;j<=n-1;j++) t=t+a[i*n+j]*b[j]; b[i]=b[i]-t; } js[n-1]=n-1; for (k=n-1;k>=0;k--) if (js[k]!=k) { t=b[k]; b[k]=b[js[k]]; b[js[k]]=t;} free(js); return(1); } /*****************************************************/
Linux联盟收集整理 ,转贴请标明原始链接,如有任何疑问欢迎来本站Linux论坛讨论 |
|