Я должен разработать алгоритм как расширение прямого исключения, которое выполняет исключения Гаусса Джордана на матрице. Моя программа выполняет и создает диагональ чисел, но они не все 1. Он также не получит доступ к первой строке и первому столбцу, чтобы изменить их на 0. И последний столбец, в котором должен быть ответ, не меняется. Любые идеи, что я мог бы сделать, чтобы приблизиться к решению?
#include <cmath>
using namespace std;
double BetterForwardElimination(double A[8][9])
{
//Implements Gaussian elimination with partial pivoting
//Input: Matrix A[1..n,1..n] and column-vector b[1..n]
//Output: An equivalent upper-triangular matrix in place ofAand the
//corresponding right-hand side values in place of the (n+1)st column
//size of array
int n = 8;
//int n = sizeof(A)/sizeof(A[0]);
for (int i = 1; i<n; i++)
{
int pivotrow = i;
for (int j=i+1; j<n; j++)
{
if (A[j][i] > A[pivotrow][i])
{
pivotrow = j;
}
}
for (int k=i; k<n-1; k++)
{
swap(A[i][k], A[pivotrow][k]);
}
for (int j=i+1; j<n; j++)
{
//int temp = A[j][i]/A[i][i];
for (int k = i; k<n; k++)
{
A[j][k] = A[j][k] - A[i][k]*(A[j][i]/A[i][i]);
}
A[i][j] = 0;
}
}
return A[n][n];
}
Мой вывод выглядит примерно так:
1 1 1 1 1 1 1 1 0
1 2 0 0 0 0 0 0 0
1 0 3 0 0 0 0 0 0
1 0 0 4 0 0 0 0 0
11 0 0 0 5 0 0 0 20
1 0 0 0 0 1 0 0 34
1 0 0 0 0 0 1 0 -51
1 0 0 0 0 0 0 -1 -6
Ожидаемый результат должен быть:
1 0 0 0 0 0 0 0 2
0 1 0 0 0 0 0 0 3
0 0 1 0 0 0 0 0 5
0 0 0 1 0 0 0 0 7
0 0 0 0 1 0 0 0 -7
0 0 0 0 0 1 0 0 -5
0 0 0 0 0 0 1 0 -3
0 0 0 0 0 0 0 1 -2