⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 guass.c

📁 提供大量C代码来实现不同功能
💻 C
字号:
#include "stdlib.h"
#include "math.h"
#include "stdio.h"

int Guass(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;
		/*下面是换主元部分,即从系数矩阵A的第K行,第K列之下的部分选出
		绝对值最大的元,交换到对角线上。*/
		for (i=k;i<=n-1;i++)
			for (j=k;j<=n-1;j++)
			{ 
				t=fabs(a[i*n+j]); /*fabs()定义在math.h中,含义是求一个浮点数的绝对值。*/
				if (t>d) { d=t; js[k]=j; is=i;}
			}
		if (d+1.0==1.0) l=0;  /*主元为0*/
		/*主元不为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;
		/*下面为矩阵A,B消元部分*/
		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("该矩阵为奇异矩阵\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);
}

main()
{ 
	int i;
	static double a[4][4]= /*系数矩阵A*/
		{ {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}; /*代数方程组Ax=B的B部分*/
	if (Guass(a,b,4)!=0) /*调用Guass消去,1为计算成功*/
		for (i=0;i<=3;i++) /*打印结果*/
			printf("x(%d)=%e\n",i,b[i]);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -