Я попытался преобразовать псевдокод исключения Гаусса - http://en.wikipedia.org/wiki/Gaussian_elimination#Pseudocode в фактическую реализацию на C. Я сделал это, я не получаю ошибок, но я получаю тот же вывод, что и ввод. Кто-нибудь знает, где можно ошибиться? В качестве импульса у меня есть матрица 3x4 A, где num обозначает количество строк (в данном случае 3), а num + 1 обозначает количество столбцов.
void GE(){
int i=1;
int j=1;
int k,u;
while(i<=num && j<=num+1){
int maxi=i;
for(k=i+1;k<num;k++){
if(abs(A[k][j])>abs(A[maxi][j])){
maxi=k;
}
}
if(A[maxi][j]!=0){
float p;
p=A[maxi][j];
A[maxi][j]=A[i][j];
A[i][j]=p;
for(u=i+1;u<num;u++){
A[u][j]=A[u][j]-A[i][j]*A[u][j];
}
}//endif
j++;
i++;
}//endwhile
редактирование:
FILE *inputMatrix=fopen("file.in","r");
fscanf(inputMatrix,"%d",&num);
for(i=0;i<num;++i){
for(j=0;j<num+1;++j){
fscanf(inputMatrix,"%f",&A[i][j]);
}
}
fclose(inputMatrix);
file.in:
3
2 1 -1 8
-3 -1 2 -11
-2 1 2 -3