2020-04-18 10:43:43 +08:00
|
|
|
#include <iostream>
|
2016-11-07 20:01:42 +08:00
|
|
|
|
2020-05-26 11:32:31 +08:00
|
|
|
int main() {
|
2019-08-21 10:10:08 +08:00
|
|
|
int mat_size, i, j, step;
|
2016-11-07 20:01:42 +08:00
|
|
|
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << "Matrix size: ";
|
|
|
|
std::cin >> mat_size;
|
2016-11-07 20:01:42 +08:00
|
|
|
|
2020-05-26 21:32:37 +08:00
|
|
|
double **mat = new double *[mat_size + 1], **x = new double *[mat_size];
|
|
|
|
for (i = 0; i <= mat_size; i++) {
|
|
|
|
mat[i] = new double[mat_size + 1];
|
|
|
|
if (i < mat_size) x[i] = new double[mat_size + 1];
|
|
|
|
}
|
2016-11-07 20:01:42 +08:00
|
|
|
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << std::endl << "Enter value of the matrix: " << std::endl;
|
|
|
|
for (i = 0; i < mat_size; i++) {
|
|
|
|
for (j = 0; j <= mat_size; j++) {
|
|
|
|
std::cin >>
|
|
|
|
mat[i][j]; // Enter (mat_size*mat_size) value of the matrix.
|
2016-11-07 20:01:42 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-26 11:32:31 +08:00
|
|
|
for (step = 0; step < mat_size - 1; step++) {
|
|
|
|
for (i = step; i < mat_size - 1; i++) {
|
2019-08-21 10:10:08 +08:00
|
|
|
double a = (mat[i + 1][step] / mat[step][step]);
|
2016-11-07 20:01:42 +08:00
|
|
|
|
2019-08-21 10:10:08 +08:00
|
|
|
for (j = step; j <= mat_size; j++)
|
|
|
|
mat[i + 1][j] = mat[i + 1][j] - (a * mat[step][j]);
|
2016-11-07 20:01:42 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << std::endl
|
|
|
|
<< "Matrix using Gaussian Elimination method: " << std::endl;
|
|
|
|
for (i = 0; i < mat_size; i++) {
|
|
|
|
for (j = 0; j <= mat_size; j++) {
|
2016-11-07 20:01:42 +08:00
|
|
|
x[i][j] = mat[i][j];
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << mat[i][j] << " ";
|
2016-11-07 20:01:42 +08:00
|
|
|
}
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << std::endl;
|
2016-11-07 20:01:42 +08:00
|
|
|
}
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << std::endl
|
|
|
|
<< "Value of the Gaussian Elimination method: " << std::endl;
|
|
|
|
for (i = mat_size - 1; i >= 0; i--) {
|
2016-11-07 20:01:42 +08:00
|
|
|
double sum = 0;
|
2020-05-26 11:32:31 +08:00
|
|
|
for (j = mat_size - 1; j > i; j--) {
|
2016-11-07 20:01:42 +08:00
|
|
|
x[i][j] = x[j][j] * x[i][j];
|
|
|
|
sum = x[i][j] + sum;
|
|
|
|
}
|
2019-08-21 10:10:08 +08:00
|
|
|
if (x[i][i] == 0)
|
2016-11-07 20:01:42 +08:00
|
|
|
x[i][i] = 0;
|
|
|
|
else
|
2019-08-21 10:10:08 +08:00
|
|
|
x[i][i] = (x[i][mat_size] - sum) / (x[i][i]);
|
2016-11-07 20:01:42 +08:00
|
|
|
|
2020-05-26 11:32:31 +08:00
|
|
|
std::cout << "x" << i << "= " << x[i][i] << std::endl;
|
2016-11-07 20:01:42 +08:00
|
|
|
}
|
2020-05-26 21:32:37 +08:00
|
|
|
|
|
|
|
for (i = 0; i <= mat_size; i++) {
|
|
|
|
delete[] mat[i];
|
|
|
|
if (i < mat_size) delete[] x[i];
|
|
|
|
}
|
|
|
|
delete[] mat;
|
|
|
|
delete[] x;
|
|
|
|
|
2019-08-21 10:10:08 +08:00
|
|
|
return 0;
|
2016-11-07 20:01:42 +08:00
|
|
|
}
|