#include <vcl.h>
#include <stdio.h>
#include <conio.h>
#include <math.h>
#define N 50
#pragma hdrstop
void glavelem( int k, double mas[] [N + 1], int n, int otv[] );
int main( void )
{
double mas[N] [N + 1];
double x[N]; //Корни системы
int otv[N]; //Отвечает за порядок корней
int i, j, k, n;
//Ввод данных
clrscr();
do
{
printf( "Vvedite chislo yravnenii sistemi: " );
scanf( "%d", & n );
if ( N < n )
printf( "Slishkom bolshoe chislo yravnenii. Povtorite vvod\n" );
}
while ( N < n );
printf( "Vvedite sistemy:\n" );
for ( i = 0; i < n; i++ )
for ( j = 0; j < n + 1; j++ )
scanf( "%lf", & mas [j] );
//Вывод введенной системы
clrscr();
printf( "sistema:\n" );
for ( i = 0; i < n; i++ )
{
for ( j = 0; j < n + 1; j++ )
printf( "%7.2f ", mas [j] );
printf( "\n" );
}
//Сначала все корни по порядку
for ( i = 0; i < n + 1; i++ )
otv = i;
//Прямой ход метода Гаусса
for ( k = 0; k < n; k++ )
{ //На какой позиции должен стоять главный элемент
glavelem( k, mas, n, otv ); //Установка главного элемента
if ( fabs( mas[k] [k] ) < 0.0001 )
{
printf( "Sistema ne imeet edinstvennogo resheniay" );
return ( 0 );
}
for ( j = n; j >= k; j-- )
mas[k] [j] /= mas[k] [k];
for ( i = k + 1; i < n; i++ )
for ( j = n; j >= k; j-- )
mas [j] -= mas[k] [j] * mas [k];
}
//Обратный ход
for ( i = 0; i < n; i++ )
x = mas [n];
for ( i = n - 2; i >= 0; i-- )
for ( j = i + 1; j < n; j++ )
x -= x[j] * mas [j];
//Вывод результата
printf( "Otvet:\n" );
for ( i = 0; i < n; i++ )
for ( j = 0; j < n; j++ )
if ( i == otv[j] )
{ //Расставляем корни по порядку
printf( "%f\n", x[j] );
break;
}
getch ();
return 0;
}
//---------------------------------------------------------------------------
//Описание функции
//----------------------------------------------
void glavelem( int k, double mas[] [N + 1], int n, int otv[] )
{
int i, j, i_max = k, j_max = k;
double temp;
//Ищем максимальный по модулю элемент
for ( i = k; i < n; i++ )
for ( j = k; j < n; j++ )
if ( fabs( mas[i_max] [j_max] ) < fabs( mas [j] ) )
{
i_max = i;
j_max = j;
}
//Переставляем строки
for ( j = k; j < n + 1; j++ )
{
temp = mas[k] [j];
mas[k] [j] = mas[i_max] [j];
mas[i_max] [j] = temp;
}
//Переставляем столбцы
for ( i = 0; i < n; i++ )
{
temp = mas [k];
mas [k] = mas [j_max];
mas [j_max] = temp;
}
//Учитываем изменение порядка корней
i = otv[k];
otv[k] = otv[j_max];
otv[j_max] = i;
}
Метод Гаусса(C).
помогите,очень надо!!заранее спасибо!!!
/Решение системы лин. уравнений методом Гаусса
Код:
[COLOR="Red"]В названии темы указывай язык программирования и оформляй код по Правилам.[/COLOR]модератор.