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

C++

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.91
Дарья Дмитренко
0 / 0 / 0
Регистрация: 10.02.2011
Сообщений: 44
#1

не могу разобраться с программой на С++. Метод Жордана-Гаусса - C++

07.04.2011, 20:34. Просмотров 1380. Ответов 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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <iostream.h>
#include <conio.h>
#include <stdlib.h>
 
void main()
{
     int colPos, rowPos;
     int i, j, k, razm;
     double max;
     double temp;
     int m_nCols;
     int m_nRows;
     double** array;
     double*  parray;
     unsigned int* ListVar;
     double* x;
     cout<<"введите размерность\n";
     cin>>razm;
     cout<<"введите матрицу:\n";
 
     m_nRows=razm;
     m_nCols=m_nRows+1;
     parray=new double[m_nRows*m_nCols];
     array=new double*[m_nRows];
     for (i=0; i<m_nRows; i++)
     {
          *(array+i)=parray+i*m_nCols;
     }
 
     ListVar=new unsigned int[m_nCols-1];
     for (j=0; j<m_nCols-1; j++)
          ListVar[j]=j+1;
 
     x=new double[razm];
 
     for (i=0; i<m_nRows-1; i++)
          x[i]=i+1;
 
     for (i=0; i<razm; i++)
          for (j=0;j<(razm+1); j++)
                cin>>array[i][j];
     for (k=0; k<m_nRows-1; k++)
     {
          colPos=rowPos=k;
          max=array[k][k];
          for (i=k; i<m_nRows; i++)
                for (j=k+1; j<m_nCols-1; j++)
                     if (abs(array[i][j])>max)
                     {
                          max=array[i][j];
                          rowPos=i;
                          colPos=j;
                     }
 
          for (i=0; i<m_nRows; i++)
          {
                temp=array[i][k];
                array[i][k]=array[i][colPos];
                array[i][colPos]=temp;
          }
 
          for (j=0; j<m_nCols; j++)
          {
                temp=array[k][j];
                array[k][j]=array[rowPos][j];
                array[rowPos][j]=temp;
          }
 
          temp=ListVar[k];
          ListVar[k]=ListVar[colPos];
          ListVar[colPos]=temp;
 
 
          for (j=m_nCols-1; j>=0; j--)
          {
                array[k][j]/=array[k][k];
 
          }
          for (j=0; j<m_nCols; j++)
                array[k][j];
          for (i=k+1; i<m_nRows; i++)
                for (j=m_nCols-1; j>=0; j--)
                     array[i][j]-=array[k][j]*array[i][k];
                }
 
     double s=0;
     x[m_nRows-1]=array[m_nRows-1][m_nCols-1]/
                            array[m_nRows-1][m_nCols-2];
     for (i=m_nRows-2; i>=0; i--)
     {
          s=0;
          for (k=i+1; k<m_nRows; k++)
                s+=array[i][k]*x[k];
                x[i]=array[i][m_nCols-1]-s;
     }
     cout<<"решение системы:\n";
     for (i=0; i<m_nRows; i++)
          cout<<"X"<<i+1<<"="<<x[i]<<endl;
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.04.2011, 20:34
Здравствуйте! Я подобрал для вас темы с ответами на вопрос не могу разобраться с программой на С++. Метод Жордана-Гаусса (C++):

Решение СЛАУ методом Гаусса-Жордана - C++ Builder
Ребят, у кого есть готовая рабочая программа, можете скинуть для ознакомления??

Разобраться с программой - C++ Builder
//--------------------------------------------------------------------------- #include &lt;vcl.h&gt; #pragma hdrstop #include...

Нужно разобраться с программой C++ (Фрактальное сжатие) - C++ Builder
Добрый день .Срочно нужна помощь !!!! программа строит различные типы фракталов и в ней есть метод сжатия изображений (Код с...

Метод Гаусса - C++ Builder
Написать программу для решения систем линейных алгебраических уравнений с помощью метода Гаусса с выбором наибольшего элемента по столбцам....

Метод Гаусса - C++ Builder
Помогите пожалуйста, мозги кипят и не справляется, в программировании новичок. Задали курсач на тему &quot;Електротехника&quot;. В общем есть...

Метод гаусса - C++ Builder
Народ помогите плиз совсем что то запутался. Программу вроде написал она запускается но не даёт вводить значения(то есть в 1 матрицу по...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
A3B5
1221 / 951 / 77
Регистрация: 20.03.2011
Сообщений: 848
07.04.2011, 22:29 #2
Цитата Сообщение от Дарья Дмитренко Посмотреть сообщение
могу указать в каком месте не понимаю. Очень прошу, дайте коментарии к программе...
Здесь - Мат. анализ.
Вам - сюда!

Удачи!
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.04.2011, 22:29
Привет! Вот еще темы с ответами:

Метод Гаусса - C++ Builder
Не могу понять в чем ошибка,кто подскажет? int A={0,1,0,1,1,0,0, 1,0,0,1,0,1,1, 1,1,1,0,0,0,0, ...

Метод Гаусса - C++ Builder
Всем привет. У меня есть решение Методом Гаусса на Делфи: var a: Matrix; b,x: Vector; h: Double; ...

Не могу написать комментарии для функции поиска, не могу разобраться... - C++ Builder
void __fastcall TForm1::FindDialog1Find(TObject *Sender) { int found, start, end; // Èíèöèàëèçàöèÿ ïåðåìåííûõ start =...

Метод Гаусса со Stringrid`om - C++ Builder
Проблема возникает при расчете столбца вектора и обратный ход... Пытаюсь найти проблему, но пока не придумал как решить... float...


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

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

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