[解決方法謝謝]我在C++中開發了下面的代碼來解決利用Gauss-Seidel方法的線性方程,但我在填充陣列時在運行時似乎有問題我無法弄清楚。這裏是我的代碼...Gauss-Seidel方法來解非線性方程
#include<stdio.h>
int main(void)
{
float a[10][10],b[10],x[10],y[10];
int n=0,m=0,i=0,j=0;
printf("Enter size of 2d array(Square matrix) : ");
scanf("%d",&n);
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("Enter values no. %d %d :",i,j);
scanf("%f",&a[i][j]);
}
}
printf("\nEnter Values to the right side of equation\n");
for(i=0;i<n;i++)
{
printf("Enter values no. %d :",i,j);
scanf("%f",&b[i]);
}
printf("Enter initial values of x\n");
for(i=0;i<n;i++)
{
printf("Enter values no. %d :",i);
scanf("%f",&x[i]);
}
printf("\nEnter the no. of iteration : ");
scanf("%d",&m);
while(m>0)
{
for(i=0;i<n;i++)
{
y[i]=(b[i]/a[i][i]);
for(j=0;j<n;j++)
{
if(j==i)
continue;
y[i]=y[i]-((a[i][j]/a[i][i])*x[j]);
x[i]=y[i];
}
printf("x%d = %f ",i+1,y[i]);
}
printf("\n\n");
m--;
}
return 0;
感謝提前:)
這不會編譯。我設法編譯運行失敗後。你可以發佈工作解決方案,沒有運行時錯誤? – 4pie0
@ privatedatapublicchannel2我試圖找出先生:( – user3490561