当前位置: 代码迷 >> C语言 >> 高手请进
  详细解决方案

高手请进

热度:176   发布时间:2004-10-15 19:48:00.0
高手请进

这是我写的一个用行主元的高斯消去法解方程组的程序,编译已通过了,但不能得到正确答案或者有float point error:domain的错误提示,请各位大虾指导一下.

#define n 4 #include <math.h> void exchrow(double a[n+1][n+1],double b[n+1])/*选主元*/ { double temp,max; int i,j,k,m; for(k=1;k<=n-1;k++) { max=fabs(a[k][k]); for(i=k+1;i<=n;i++) if(fabs(a[i][k]>max)) {max=fabs(a[i][k]); m=i;} if(k!=m) {for(j=1;j<=n;j++) { temp=a[k][j]; a[k][j]=a[m][j]; a[m][j]=temp;} temp=b[m];b[m]=b[k];b[k]=temp;} } } void eliminate(double a[n+1][n+1],double b[n+1])/*消元*/ { int i,j,k; for(k=1;k<=n-1;k++) {for(i=k+1;i<=n;i++) {for(j=k;j<=n;j++) a[i][j]=a[i][j]-a[k][j]*a[i][k]/a[k][k]; b[i]=b[i]-b[k]*a[i][k]/a[k][k]; } } } void backsub(double a[n+1][n+1],double b[n+1])/*回代*/ { int i,j; double sum=0.0; b[n]=b[n]/a[n][n];/*解得的x[i]存放在b[i]中*/ for(i=n-1;i>=1;i--) {for(j=i+1;j<=n;j++) sum+=a[i][j]*b[j]; b[i]=(b[i]-sum)/a[i][i];} } main() {double a[n+1][n+1],b[n+1]; int i,j; printf("input a\n"); for(i=1;i<=n;i++) for(j=1;j<=n;j++) { printf("a[%d][%d]=",i,j); scanf("%f",&a[i][j]);} printf("input b\n"); for(i=1;i<=n;i++) {printf("b[%d]=",i); scanf("%f",&b[i]);} exchrow(a,b); eliminate(a,b); backsub(a,b); printf("root is\n"); for(i=1;i<=n;i++) printf("x[%d]=%f\n",i,b[i]); }

搜索更多相关的解决方案: 高斯  max  fabs  double  

----------------解决方案--------------------------------------------------------

天哪,这里人气这么旺,怎么没人给我指点一下啊


----------------解决方案--------------------------------------------------------

没有仔细研究你的算法,只是大概看了一下语法方面的问题

main() {double a[n+1][n+1],b[n+1]; /*不能用变量来定义数组下标*/ int i,j; printf("input a\n"); for(i=1;i<=n;i++) for(j=1;j<=n;j++) { printf("a[%d][%d]=",i,j); scanf("%f",&a[i][j]);} printf("input b\n"); for(i=1;i<=n;i++) {printf("b[%d]=",i); scanf("%f",&b[i]);} exchrow(a,b); /*还要加上数组个数的参数*/ eliminate(a,b); /*同上*/ backsub(a,b); /*同上*/ printf("root is\n"); for(i=1;i<=n;i++) printf("x[%d]=%f\n",i,b[i]); }


----------------解决方案--------------------------------------------------------
不是不想帮,我没学过数值分析。
----------------解决方案--------------------------------------------------------

简单的语法错误!

scanf("%f",&a[i][j]);} scanf("%f",&b[i]);}

是%lf


----------------解决方案--------------------------------------------------------

3楼大概没看见我开始的宏定义 5楼的意见很对.但还是有错误,谁能帮我看一下算法有什么错误


----------------解决方案--------------------------------------------------------
  相关解决方案