我已经为高斯消除方法编写了这段代码:
#include <stdio.h>
int main()
{
float arr[3][4]={{0}}, i, j, k, p;
printf("Enter the coefficients:-\n");
for(i=0; i<3;i++)
{
printf("Row #(%d)\n", (int)(i+1));
for(j=0; j<4; j++)
{
scanf("%f", &arr[(int)i][(int)j]);
}
}
for(k=1, p=(k-1); (k<=2); k++, p++)
{
for(i=k; i<=2; i++)
{
for(j=0; j<=3; j++)
{
arr[(int)i][(int)j]-=((arr[(int)i][(int)p]/arr[(int)p][(int)p])*arr[(int)p][(int)j]);
}
}
}
for(i=0; i<3;i++)
{
for(j=0; j<4; j++)
{
printf("%0.3f ", arr[(int)i][(int)j]);
}
printf("\n");
}
return 0;
}
但是,它不会打印正确的输出值。对输出的分析表明这些值已被四舍五入或其他东西。我猜某处二维数组的整数值已被考虑,即使我已将该数组作为双精度并且仅对语法有效的元素地址使用类型转换。您可以通过以下矩阵自行尝试:
R1- 10 -1 2 4
R2- 1 10 -1 3
R3- 2 3 20 7
正确的输出应该是:
R1- 10 -1 2 4
R2- 0 10.1 -1.2 2.6
R3- 0 0 19.980 5.376
我正在使用 GNU GCC 编译器。