Форум программистов, компьютерный форум CyberForum.ru

метод гаусса - C++

Восстановить пароль Регистрация
 
kisya8
0 / 0 / 0
Регистрация: 01.05.2009
Сообщений: 18
05.11.2011, 16:56     метод гаусса #1
Помогите,пожалуйста
Преподаватель попросил расписать программу по блокам

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(); 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.11.2011, 16:56     метод гаусса
Посмотрите здесь:

Метод Гаусса!!! C++
Метод Гаусса в С++ C++
C++ Метод Гаусса
метод Гаусса C++
Метод Гаусса C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Jupiter
05.11.2011, 17:01
  #2

Не по теме:

Цитата Сообщение от kisya8 Посмотреть сообщение
Преподаватель попросил расписать программу по блокам
считайте что он вас пожалел, некаждыйумеетчитатьтекстнаписаныйслитно

vladmuskat
1 / 1 / 0
Регистрация: 12.01.2011
Сообщений: 9
05.11.2011, 18:25     метод гаусса #3
она правильно работает ???
Мне просто в школе задали написать программу, котрорая решает систему уравнений методом Гауса
kisya8
0 / 0 / 0
Регистрация: 01.05.2009
Сообщений: 18
05.11.2011, 19:00  [ТС]     метод гаусса #4
Если честно, не знаю. Мне просто главное разбить её на блоки.а рабочая она или нет, не важно )
Yandex
Объявления
05.11.2011, 19:00     метод гаусса
Ответ Создать тему
Опции темы

Текущее время: 03:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru