Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
vladmuskat
1 / 1 / 0
Регистрация: 12.01.2011
Сообщений: 9
#1

Метод Гаусса - C++

05.11.2011, 18:49. Просмотров 690. Ответов 3
Метки нет (Все метки)

В школе задали написать программу , которая решает систему уравнений методом Гаусса.
Матрица квадратная (колличество строк = колличеству коэффициентов).
Я вроде нашёл на форуме программу но не понимаю как она работает

Добавлено через 2 минуты
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include "stdio.h"
#include "conio.h"
#include <iostream>
#include <string.h>
#include <stdio.h> // ГЋГЇГЁГ±Г*Г*ГЁГї ГґГіГ*êöèé ââîäГ*-âûâîäГ*
#include <math.h> // ГЋГЇГЁГ±Г*Г*ГЁГї Г¬Г*ГІГҐГ¬Г*ГІГЁГ·ГҐГ±ГЄГЁГµ ГґГіГ*êöèé
using namespace std;
const int n=3; 
void ReadData()
{ int n;
double A[n][n];
{ fscanf(f,"%d",&n);
printf("Sborka matritsi m- na n-:\n");
for (int i=0;i<n;i++)
{ for(int j=0;j<n;j++)
{ fscanf(f,"%d",&A[i][j]);
printf("%d",A[i][j]);
} printf("\n");
} printf("\n\n");
fclose(f); } }
void Gauss
( double X[n], const double Z[n][n], const double Y[n])
{ ReadData();
double A[n][n]; // Г¬Г*òðèöГ* êîýôôèöåГ*òîâ ГѓГ*ГіГ±Г±Г*
double B[n]; // Г°Г*áî÷èé Г¬Г*Г±Г±ГЁГў ñâîáîäГ*ûõ ÷ëåГ*îâ
int i,
int j,
int k; // Г°Г*áî÷èå ïåðåìåГ*Г*ûå
for( i = 0; i < n; i++ ) // êîïèðîâГ*Г*ГЁГҐ Гў Г°Г*áî÷óþ Г¬Г*òðèöó A
{ for( j = 0; j < n; j++ ) 
A[i][j] = Z[i][j];
B[i] = Y[i]; // êîïèðîâГ*Г*ГЁГҐ ñâîáîäГ*ûõ ÷ëåГ*îâ
X[i] = 0; }
for( k = 0; k < n-1; k++ )
for( i = k+1; i < n; i++ ) // ïðåîáðГ*çîâГ*Г*ГЁГҐ ñòðîê
{ double r = A[i][k] / A[k][k];
for( j = k; j < n; j++ )
A[i][j] -= A[k][j] * r;
B[i] -= B[k] * r;
}
X[n-1] = B[n-1] / A[n-1][n-1];
 
for( i = n-2; i >= 0; i-- )
{ double s = 0;
for( j = i+1; j < n; j++ ) 
s += A[i][j] * X[j];
X[i] = ( B[i] - s ) / A[i][i];
} printf( "\n" );
for( i = 0; i < n; i++ ) 
{ printf( "\n" ); 
for( j = 0; j < n; j++ ) 
printf( "%8.2lf", A[i][j] );
printf( " %8.2lf", B[i] );
} }
void main( void )
{ ReadData();
double X[n]; // êîðГ*ГЁ ñèñòåìû ëèГ*ГҐГ©Г*ûõ ГіГ°Г*ГўГ*ГҐГ*ГЁГ©
short i, j; // Г°Г*áî÷èå ïåðåìåГ*Г*ûå
printf( " matritsa A* matritsa B\n" ); 
for( i = 0; i < n; i++ ) // öèêë ñòðîê
{ printf( "\n" ); // Г*îâГ*Гї ñòðîêГ* Г*Г* ìîГ*èòîðå 
for( j = 0; j < n; j++ )
printf( "%8.2lf", A[i][j] );
printf( " %8.2lf", B[i] ); 
} printf( "\n" ); 
printf( "stypen4atii vid matritsi \n" ); 
Gauss( X, A, B ); // ðåøåГ*ГЁГҐ ìåòîäîì ГѓГ*ГіГ±Г±Г*
printf( "\n" );
printf( "\n" );
printf( " zna4enia peremennih x1,x1,x3\n" ); 
printf( "\n X = " );
for( i = 0; i < n; i++ )
 
printf( "%8.2lf", X[i] );
printf( "\n" );
printf( "\n" );
printf( "rang=\n" );
getch(); 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.11.2011, 18:49
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Метод Гаусса (C++):

СЛАУ. Метод обратной матрицы, метод Гаусса, метод Крамера, метод Зейделя - C++
Помогите ребят. Не могу построить алгоритмы для этих методов Язык C++

Метод Гаусса - C++
Помогите, пожалуйста, написать программу. Вот условие: Написать программу решения системы уравнений методом Гаусса. С ее помощью...

метод Гаусса - C++
Помогите пожалуйста написать программу на С++ Задана система линейного уравнения:MA*X=B. Для решения уравнения использовать метод Гаусса

Метод Гаусса - C++
Суть в том что бы СЛАУ методом Гаусс с последовательным исключениям неизвестных.Вот система: 2.7x+3.3y+1.3z=2.1 3.5x-1.7y+2.8z=1.7 ...

метод гаусса - C++
Помогите,пожалуйста Преподаватель попросил расписать программу по блокам #include &quot;stdio.h&quot; #include &quot;conio.h&quot; #include...

метод Гаусса - C++
Знаю что тема поднималась много раз но все же, можете продемонстрировать решение хотя бы 3 уравнений (желательно 4) но без считывания и...

3
BRcr
4010 / 2299 / 155
Регистрация: 03.02.2011
Сообщений: 5,064
Записей в блоге: 10
05.11.2011, 19:04 #2
Цитата Сообщение от vladmuskat Посмотреть сообщение
Я вроде нашёл на форуме программу но не понимаю как она работает
А она работает?
Що-то сомнительно смотрится...
0
vladmuskat
1 / 1 / 0
Регистрация: 12.01.2011
Сообщений: 9
05.11.2011, 19:10  [ТС] #3
я не знаю. у меня на компе не работает ,это либо из-за того что прога не правильная, либо из-зи того что бибилиотеки не хватает
0
BRcr
4010 / 2299 / 155
Регистрация: 03.02.2011
Сообщений: 5,064
Записей в блоге: 10
06.11.2011, 19:58 #4
смотри здесь...
... и научись толком пользоваться поиском, сэкономишь себе уйму времени.
1
06.11.2011, 19:58
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.11.2011, 19:58
Привет! Вот еще темы с ответами:

Метод Гаусса - C++
Всем привет. Ребят, что скажите по поводу такой реализации метода Гаусса: #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;math.h&gt;...

Метод Гаусса!!! - C++
Всем привет! )) У меня вот такая проблемка! Нужно решить СЛАУ методом Гаусса с выбором главного элемента по столбцу!! Теоретически знаю, а...

Метод Гаусса - C++
Как решить квадратную матрицу методом Гаусса, я ее привел к треугольному виду, не могу понять как дальше быть....

метод гаусса - C++
найти метод гаусса n+1 значение определителя в n+1 точке, а затем решить систему из n+1 уравнение с n+1 неизвестными. составить...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.