| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 369 人关注过本帖
标题:[讨论]哪里错了
取消只看楼主 加入收藏
xuyandemen
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2006-11-3
收藏
 问题点数:0 回复次数:0 
[讨论]哪里错了

#include <stdio.h>
#include <math.h>
#include <stdlib.h>

int rgauss(n,a,b)
int n;
double a[],b[];
{
int *js,L,i,j,k,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);
}

这是全主元高斯消去法的程序,运行时提示有错,大家帮忙给看看。

搜索更多相关主题的帖子: include double 
2006-11-06 20:06
快速回复:[讨论]哪里错了
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024306 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved