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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Циклический список http://www.cyberforum.ru/cpp/thread272034.html
Реализовать структуры данных «циклический список».
C++ Кто может дать пояснения к программе на С++? Метод Жордана-Гаусса Метод решения систем уравнений. То же самое, что и метод Гаусса, только если ведущий элемент ноль - строки местами меняются. Строка, которая становится на место нуля, выбирается как максимум среди первых элементов. Программу впринципе поняла, кроме некоторый моментов. Кто может дать пояснения? #include <iostream.h> #include <conio.h> #include <stdlib.h> void main() { int colPos,... http://www.cyberforum.ru/cpp/thread272025.html
Найти сумму тех элементов, в запись которых входит ровно две цифры C++
Задача: Дан одномерный массив из N элементов. Найти сумму тех элементов, в запись которых входит ровно две цифры. Пример: 112212 Делал все это через циклы определяя последние 2 цифры элемента и сравнивал с ними остальные. Получилась большая программа. Говорят можно сделать проще, а именно через некую функцию (которой я естественно не знаю). Не подскажите что за функция? Добавлено через 1...
C++ Работа с файлами и строками
Здравствуйте. Помогите пожалуйста с решением. ЗАДАНИЕ: Дан текстовый файл содержащий строки. Занести эти строки в другой текстовый файл, отсортировав их по убыванию количества слов заданной длины не содержащих цифр. Длина слова вводится с клавиатуры. Использовать только библиотеки "iostream.h" и "fstream.h", а также возможно и ""conio.h". Нужно сделать с использованием функций, указателей и...
C++ Book http://www.cyberforum.ru/cpp/thread271948.html
Подскажите пожалуйста книгу по чистому С без объектов и прочего, страниц на 200, что бы легко читалось и было информативно.
C++ Разработка класса Разработать класс описывающий множество точек на плоскости, определить для экземпляров класса операцию объединения множество и операция пересечение множеств. Реализовать метод возвращающий периметр многоугольника покрывающий все множество точек и имеющий наименьшую возможную площадь. Предусмотреть возможность выборам пользователя определение типа данных для координат. P.S. Каждый элемент... подробнее

Показать сообщение отдельно
Дарья Дмитренко
0 / 0 / 0
Регистрация: 10.02.2011
Сообщений: 44

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

07.04.2011, 20:34. Просмотров 1369. Ответов 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:32. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru