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

Кто может дать пояснения к программе на С++? Метод Жордана-Гаусса - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Найти сумму тех элементов, в запись которых входит ровно две цифры http://www.cyberforum.ru/cpp-beginners/thread272021.html
Задача: Дан одномерный массив из N элементов. Найти сумму тех элементов, в запись которых входит ровно две цифры. Пример: 112212 Делал все это через циклы определяя последние 2 цифры элемента и сравнивал с ними остальные. Получилась большая программа. Говорят можно сделать проще, а именно через некую функцию (которой я естественно не знаю). Не подскажите что за функция? Добавлено через 1...
C++ Работа с файлами и строками Здравствуйте. Помогите пожалуйста с решением. ЗАДАНИЕ: Дан текстовый файл содержащий строки. Занести эти строки в другой текстовый файл, отсортировав их по убыванию количества слов заданной длины не содержащих цифр. Длина слова вводится с клавиатуры. Использовать только библиотеки "iostream.h" и "fstream.h", а также возможно и ""conio.h". Нужно сделать с использованием функций, указателей и... http://www.cyberforum.ru/cpp-beginners/thread271962.html
C++ Book
Подскажите пожалуйста книгу по чистому С без объектов и прочего, страниц на 200, что бы легко читалось и было информативно.
Разработка класса C++
Разработать класс описывающий множество точек на плоскости, определить для экземпляров класса операцию объединения множество и операция пересечение множеств. Реализовать метод возвращающий периметр многоугольника покрывающий все множество точек и имеющий наименьшую возможную площадь. Предусмотреть возможность выборам пользователя определение типа данных для координат. P.S. Каждый элемент...
C++ Как созадть такой экземпляр? http://www.cyberforum.ru/cpp-beginners/thread271634.html
Пусть есть класс: class A { protected: type field; .... }; а выше описан тип (возможно класс, или структура) type, или макрос type - синоним существующего (возможно стандартного) типа. В классе нет открытых членов, прямо, или косвенно пишуших член field. Как создать экземпляр класса A с определённым значением члена field?
C++ Что такое инстанцирование? class A { ... }; A a; // Это уже инстанцирование A? подробнее

Показать сообщение отдельно
Дарья Дмитренко
0 / 0 / 0
Регистрация: 10.02.2011
Сообщений: 44
07.04.2011, 20:04     Кто может дать пояснения к программе на С++? Метод Жордана-Гаусса
Метод решения систем уравнений. То же самое, что и метод Гаусса, только если ведущий элемент ноль - строки местами меняются. Строка, которая становится на место нуля, выбирается как максимум среди первых элементов.
Программу впринципе поняла, кроме некоторый моментов.
Кто может дать пояснения?
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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:12. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru