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

Описание класса матрицы - C++

Восстановить пароль Регистрация
 
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 08:34     Описание класса матрицы #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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
#include <iostream>
#include <conio.h>
#include <time.h>
using namespace std;
class Matrix{
int **mtx;     //здесь хранится матрица
int **transmtx;    // здесь хранится транспонированная матрица
int size;           //переменная для размера матрицы
public:
Matrix(char type ,int size);
Matrix(){}
//операция сложения, вычитания и умножения матриц
Matrix Add(Matrix ob);
Matrix Sub(Matrix ob);
Matrix Mul(Matrix ob);
Matrix Transp(Matrix ob); //операция транспонирования матрицы
Matrix Sumtransp(Matrix ob);  // операция транспонирования и суммирования матриц
Matrix Zamena(Matrix ob);     // операция по замене элемента
//операции вычисления сумму элементов на
//диагонали и суммы всех элементов и нахождения реднего арифметического области
int SumDiagElements();
int SumAllElements();
int  SrAr();            //показать матрицу
void ShowMatrix();
//получить размер матрицы
int GetSize(){ return size; }
//проверяет является ли индекс  элемента допустимым
bool isValidIndex(int x){
if(x < 0 || x > size - 1) return false;
return true;    }
//после ввода матрицы, если необходимо изменяет значение элементов
bool CorrectElem();
//функция выбора операции над матрицами
static void ChoirOperations(char &ch);
//функция выбора способа заполнения матрицы
static void ChoirFillMatrix(char &ch);};
bool Matrix::CorrectElem(){
int i,j,change_val;
char ch;
do{
cout << "Xotite izmenit peremennie matrici (0- net, 1-da): ";
fflush(stdin);
}while(scanf("%c",&ch)!=1 || cin.rdbuf()->in_avail()!=1 || ch!='0' && ch !='1');
if(ch == '0') return false;
do{
cout << "Vvdedite nomer stroki: ";
fflush(stdin);
}while(scanf("%i",&i)!=1 || cin.rdbuf()->in_avail()!=1 || !isValidIndex(i));
do{
cout << "Vvedite nomer stolbca: ";
fflush(stdin);}
 
 
while(scanf("%i",&j)!=1 || cin.rdbuf()->in_avail()!=1 || !isValidIndex(j));
do{
printf("Vvedite novoe znachenie elementa mtx[%i][%i]: ",i,j);
fflush(stdin);
}while(scanf("%i",&change_val)!=1 || cin.rdbuf()->in_avail()!=1);
mtx[i][j] = change_val % 100;
return true;}
void Matrix::ShowMatrix(){        //функция вывода матрицы
int i,j;
for(i=0; i<size; i++){
for(j=0;j<size;j++){
cout.width(9);
cout << mtx[i][j] << ' ';}
cout << "\n";   }
cout << "\n";}
void Matrix::ChoirOperations(char &ch){
cout   << "1.Symma matric.\n"
<< "2.Raznost matric.\n"
<< "3.Ymnoshenie matric.\n"
<< "4.Transponirovat` matricu.\n"
<< "5.Slozhit` transponirovannuy matricu s ishodnoy.\n"
<< "6.Srednee arifmeticheskoe elementov nad glavnoi i pobochnoi digonal`yu.\n"
<< "7.Zamenit1 elementy nad glavnoy diagonal`yu na na bol`shee iz polozhitel`nyh i otricatel`nyh.\n"
<< "8.Symma elementov na diagonali.\n"
<< "9.Symma vsex elementov.\n";
do{
cout << "Videbite odin iz pynktov (0 dlia vixoda): ";
fflush(stdin);
}while(scanf("%c",&ch)!=1 || cin.rdbuf()->in_avail()!=1 ||
ch < '0' || ch > '9');
}
void Matrix::ChoirFillMatrix(char &ch){
cout << "r-slychainaia matrica.\n"
<< "m-rychnoi vvod.\n";
do{
cout << "Viberite odin iz pynktov: ";
fflush(stdin);
}while(scanf("%c",&ch)!=1 || cin.rdbuf()->in_avail()!=1 ||
ch != '0' && ch != '1' &&ch!='r' && ch!='m');
}
Matrix::Matrix(char type,int s){
int i,j;
if(s < 1) size = 1;
else if(s > 10) size = 10;
else size = s;
mtx = new int *[size];
for(i=0; i<size; i++)
mtx[i] = new int[size];
switch(type){
break;
case'r':
srand(time(NULL));
for(i=0; i<size; i++)
 
for(j=0; j<size; j++)
mtx[i][j] = rand() % 100;
break;
case'm':
cout << "\n";
for(i=0; i<size; i++)
for(j=0; j<size; j++){
do{
cout << "vvedite element mtx[" << i << "][" << j << "]: ";
fflush(stdin);
}while(scanf( "%i",&mtx[i][j])!=1 || cin.rdbuf()->in_avail()!=1);
mtx[i][j]%=100-50;
}
break;  }}
 
Matrix Matrix::Add(Matrix ob){           //функция сложения матриц
Matrix result('0',size);
int i,j;
 
for(i=0; i<size;i++)
for(j=0;j<size;j++)
result.mtx[i][j] = mtx[i][j] + ob.mtx[i][j];
return result;}
Matrix Matrix::Sub(Matrix ob){                     //функция вычитания матриц
Matrix result('0',size);
int i,j;
for(i=0; i<size;i++)
for(j=0;j<size;j++)
result.mtx[i][j] = mtx[i][j] - ob.mtx[i][j];
return result;}
Matrix Matrix::Mul(Matrix ob){               // функция произведения матриц
Matrix result('0',size);
int i,j,k;
for(k=0; k<size;k++)
for(i=0;i<size;i++)
for(j=0;j<size;j++)
result.mtx [k][i]= result.mtx[k][i] + mtx[k][j] * ob.mtx[j][i];
return result;}
int Matrix::SumAllElements(){    // функция нахождения суммы всех элементов матрицы
int result = 0;
 
for(int i=0; i<size; i++)
for(int j=0; j<size; j++)
result+=mtx[i][j];
return result;}
int Matrix::SumDiagElements(){ //функция нахождения суммы диагональных элементов
int result = 0;
for(int i=0; i<size; i++)
result+=mtx[i][i];
 
return result;
}
Matrix Matrix::Transp(Matrix ob) {  //функция транспонирования матрицы
Matrix result('0',size);
int i,j;
 
for(int i=0; i<size; i++)
for(int j=0; j<size; j++)
result.mtx[i][j] = mtx[j][i] ;
return result; }
Matrix Matrix::Sumtransp(Matrix ob){       //функция транспонирования и сложения с исходной матрицей
Matrix result('0',size);
int i,j;
for(int i=0; i<size; i++)
for(int j=0; j<size; j++)
result.mtx[i][j]=mtx[i][j]+mtx[j][i];
return result; }
int Matrix::SrAr(){    //функция нахождения среднего арифметического области над диагоналями
int result = 0;
int i,j,z ;
for(int i=0; i<size; i++)
for(int j=0; j<size; j++)
if (( (i+j)<=(size+0)   ) && (i<=j) )
{result +=(double) mtx[i][j];
z=z+1;}
result /=(double)  z;
return result; }
Matrix Matrix::Zamena(Matrix ob){ //функция сравнения количества положительных и отрицательных элементов
Matrix result('0',size);                            //и замены на большее из них элементов под главной диагональю
int k=0; int l=0;
int i,j;
for(int i=0; i<=size; i++) {
for(int j=0; j<=size; j++) {
if (mtx[i][j]>0)
k=k+1;
else l=l+1;}}
for(int i=0; i<=size; i++) {
for(int j=0; j<size; j++) {
if (i==j) {
if (k>l )
{ mtx[i][j]=k;}
else mtx[i][j]=l; }}
result.mtx[i][j] = mtx[i][j];
return result; }  }
void main(){
char ch_fill1;         //выбор заполнения 1 матрицы
char ch_fill2;         //выбор заполнения 2 матрицы
char ch_operations;    //выбор операции
int size;
setlocale(LC_ALL,"Rus");
for(;;){
system("cls");
Matrix::ChoirOperations(ch_operations);    //выбираем операцию над матрицами
if(ch_operations == '0') break;            //тут выходим, если надо
cout << "\n";
//узнаем размер матриц
do{
 
cout << "Vvedite razmer matric: ";
fflush(stdin);
}while(scanf("%i",&size)!=1 || cin.rdbuf()->in_avail()!=1);
Matrix result;  //матрица для хранения результата аримфетических операций
if(ch_operations > '0' && ch_operations < '4'){
cout << "\nMatrica 1:\n";
Matrix::ChoirFillMatrix(ch_fill1);  //выберем способ заполнения матрицы 1
Matrix ob(ch_fill1,size);           //создали 1 матрицу
cout << "\n";
//показываем и корректируем матрицу 1, если это необходимо
do{
cout << "Vi vveli matricy 1:\n";
ob.ShowMatrix();
}while(ob.CorrectElem());
cout << "\nMatrica 2:\n";
Matrix::ChoirFillMatrix(ch_fill2);    //выберем способ заполения 2 матрицы
Matrix ob2(ch_fill2,size);            //создали 2 матрицу
cout << "\n";
//показываем и корректируем матрицу 2, если это необходимо
do{
cout << "Vi vveli matricy 2:\n";
ob2.ShowMatrix();
}while(ob2.CorrectElem());
//переходим к реализации арифметических операции
switch(ch_operations){
case'1':
result = ob.Add(ob2);          //сложим матрицы и поместим результат в result
cout << "\Rezyltat sloshenia:\n";
result.ShowMatrix();           //покажем результат сложения
break;
case'2':
result = ob.Sub(ob2);          //вычитания матриц и размещение результат в result
cout << "\nRezyltat vicitania :\n";
result.ShowMatrix();           //показать результат вычитания
break;
case'3':
result = ob.Mul(ob2);           //умножим матрицы и помести результат в result
cout << "\nRezyltat ymnoshenia\n";
result.ShowMatrix();            //покажем результат умножения матриц
break;
}      // выбор действий требующих воода только одной матрицы
}/*else*/ if(ch_operations >= '4' && ch_operations < '10'){
cout << "\nMatrica :\n";
Matrix::ChoirFillMatrix(ch_fill1);         //выбор способа заполнения матрицы
Matrix ob(ch_fill1,size);                  //создать матрицу с заданными параметрами
 
//показывает и корректирует матрицу, если это требуется
do{
cout << "\nVi vveli matricy :\n";
ob.ShowMatrix();
}while(ob.CorrectElem());
switch(ch_operations){
case '4':
result = ob.Transp(ob);                     // транспонируем матрицу и поместим результат в result
cout << "\nTransponirovannaya matrica:\n";
 
result.ShowMatrix();     // покажем результат транспонирования матриц
break;
case '5':
result = ob.Sumtransp(ob);  // транспонируем и складываем матрицы и записываем результат в result
cout << "\nSumma ishodnoi s tranponirovannoi:\n";
result.ShowMatrix();                         //выводим получившийся результат
break;
case '6':
cout << "\nSrednee arifmetixheskoe elementov nad diagonalyuami:\n";
cout << ob.SrAr() << "\n";         //выводим значение среднего арифметического области
break;
case '7':
result = ob.Zamena(ob);          //выводим матрицу с замененными элементами
cout << "\nMatrica s zamenoi:\n";
result.ShowMatrix();
break;
case'8':
cout << "\nSymma elementov na diagonali: ";
cout << ob.SumDiagElements() << "\n";  // выводим сумму диагональных элементов
break;
case'9':
cout << "\nSymma vsex elementov: ";
cout << ob.SumAllElements() << "\n";   //выводим сумму всех элементов матрицы
break;  }       }
cout << "Dlia prodolshenia nashmite lybyiy knopky.";
getch();    }}
Код программы.rar
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 09:31     Описание класса матрицы #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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
#include <iostream>
#include <conio.h>
#include <time.h>
using namespace std;
class Matrix
{
        int **mtx;     //здесь хранится матрица
        int **transmtx;    // здесь хранится транспонированная матрица
        int size;           //переменная для размера матрицы
    public:
        Matrix(char type, int size);
        Matrix()
        {
        }
//операция сложения, вычитания и умножения матриц
        Matrix Add(Matrix ob);
        Matrix Sub(Matrix ob);
        Matrix Mul(Matrix ob);
        Matrix Transp(Matrix ob); //операция транспонирования матрицы
        Matrix Sumtransp(Matrix ob); // операция транспонирования и суммирования матриц
        Matrix Zamena(Matrix ob);     // операция по замене элемента
//операции вычисления сумму элементов на
//диагонали и суммы всех элементов и нахождения реднего арифметического области
        int SumDiagElements();
        int SumAllElements();
        int SrAr();         //показать матрицу
        void ShowMatrix();
//получить размер матрицы
        int GetSize()
        {
            return size;
        }
//проверяет является ли индекс  элемента допустимым
        bool isValidIndex(int x)
        {
            if (x < 0 || x > size - 1) return false;
            return true;
        }
//после ввода матрицы, если необходимо изменяет значение элементов
        bool CorrectElem();
//функция выбора операции над матрицами
        static void ChoirOperations(char &ch);
//функция выбора способа заполнения матрицы
        static void ChoirFillMatrix(char &ch);
};
bool Matrix::CorrectElem()
{
    int i, j, change_val;
    char ch;
    do
    {
        cout << "Xotite izmenit peremennie matrici (0- net, 1-da): ";
        fflush (stdin);
    } while (scanf("%c" , &ch) != 1 || cin.rdbuf()->in_avail() != 1 || ch != '0' && ch != '1');
    if (ch == '0') return false;
    do
    {
        cout << "Vvdedite nomer stroki: ";
        fflush (stdin);
    } while (scanf("%i" , &i) != 1 || cin.rdbuf()->in_avail() != 1 || !isValidIndex(i));
    do
    {
        cout << "Vvedite nomer stolbca: ";
        fflush (stdin);
    }
 
    while (scanf("%i" , &j) != 1 || cin.rdbuf()->in_avail() != 1 || !isValidIndex(j));
    do
    {
        printf("Vvedite novoe znachenie elementa mtx[%i][%i]: " , i , j);
        fflush (stdin);
    } while (scanf("%i" , &change_val) != 1 || cin.rdbuf()->in_avail() != 1);
    mtx[i][j] = change_val % 100;
    return true;
}
void Matrix::ShowMatrix()
{        //функция вывода матрицы
    int i, j;
    for (i = 0; i < size; i++)
    {
        for (j = 0; j < size; j++)
        {
            cout.width(9);
            cout << mtx[i][j] << ' ';
        }
        cout << "\n";
    }
    cout << "\n";
}
void Matrix::ChoirOperations(char &ch)
{
    cout << "1.Symma matric.\n" << "2.Raznost matric.\n" << "3.Ymnoshenie matric.\n" << "4.Transponirovat` matricu.\n" << "5.Slozhit` transponirovannuy matricu s ishodnoy.\n" << "6.Srednee arifmeticheskoe elementov nad glavnoi i pobochnoi digonal`yu.\n" << "7.Zamenit1 elementy nad glavnoy diagonal`yu na na bol`shee iz polozhitel`nyh i otricatel`nyh.\n" << "8.Symma elementov na diagonali.\n" << "9.Symma vsex elementov.\n";
    do
    {
        cout << "Videbite odin iz pynktov (0 dlia vixoda): ";
        fflush (stdin);
    } while (scanf("%c" , &ch) != 1 || cin.rdbuf()->in_avail() != 1 || ch < '0' || ch > '9');
}
void Matrix::ChoirFillMatrix(char &ch)
{
    cout << "r-slychainaia matrica.\n" << "m-rychnoi vvod.\n";
    do
    {
        cout << "Viberite odin iz pynktov: ";
        fflush (stdin);
    } while (scanf("%c" , &ch) != 1 || cin.rdbuf()->in_avail() != 1 || ch != '0' && ch != '1' && ch != 'r' && ch != 'm');
}
Matrix::Matrix(char type, int s)
{
    int i, j;
    if (s < 1) size = 1;
    else
        if (s > 10) size = 10;
        else size = s;
    mtx = new int *[size];
    for (i = 0; i < size; i++)
        mtx[i] = new int[size];
    switch (type)
    {
        break;
    case 'r':
        srand(time(NULL));
        for (i = 0; i < size; i++)
 
            for (j = 0; j < size; j++)
                mtx[i][j] = rand() % 100;
        break;
    case 'm':
        cout << "\n";
        for (i = 0; i < size; i++)
            for (j = 0; j < size; j++)
            {
                do
                {
                    cout << "vvedite element mtx[" << i << "][" << j << "]: ";
                    fflush (stdin);
                } while (scanf("%i" , &mtx[i][j]) != 1 || cin.rdbuf()->in_avail() != 1);
                mtx[i][j] %= 100 - 50;
            }
        break;
    }
}
 
Matrix Matrix::Add(Matrix ob)
{           //функция сложения матриц
    Matrix result('0' , size);
    int i, j;
 
    for (i = 0; i < size; i++)
        for (j = 0; j < size; j++)
            result.mtx[i][j] = mtx[i][j] + ob.mtx[i][j];
    return result;
}
Matrix Matrix::Sub(Matrix ob)
{                     //функция вычитания матриц
    Matrix result('0' , size);
    int i, j;
    for (i = 0; i < size; i++)
        for (j = 0; j < size; j++)
            result.mtx[i][j] = mtx[i][j] - ob.mtx[i][j];
    return result;
}
Matrix Matrix::Mul(Matrix ob)
{               // функция произведения матриц
    Matrix result('0' , size);
    int i, j, k;
    for (k = 0; k < size; k++)
        for (i = 0; i < size; i++)
            for (j = 0; j < size; j++)
                result.mtx[k][i] = result.mtx[k][i] + mtx[k][j] * ob.mtx[j][i];
    return result;
}
int Matrix::SumAllElements()
{    // функция нахождения суммы всех элементов матрицы
    int result = 0;
 
    for (int i = 0; i < size; i++)
        for (int j = 0; j < size; j++)
            result += mtx[i][j];
    return result;
}
int Matrix::SumDiagElements()
{ //функция нахождения суммы диагональных элементов
    int result = 0;
    for (int i = 0; i < size; i++)
        result += mtx[i][i];
 
    return result;
}
Matrix Matrix::Transp(Matrix ob)
{  //функция транспонирования матрицы
    Matrix result('0' , size);
    int i, j;
 
    for (int i = 0; i < size; i++)
        for (int j = 0; j < size; j++)
            result.mtx[i][j] = mtx[j][i];
    return result;
}
Matrix Matrix::Sumtransp(Matrix ob)
{       //функция транспонирования и сложения с исходной матрицей
    Matrix result('0' , size);
    int i, j;
    for (int i = 0; i < size; i++)
        for (int j = 0; j < size; j++)
            result.mtx[i][j] = mtx[i][j] + mtx[j][i];
    return result;
}
int Matrix::SrAr()
{    //функция нахождения среднего арифметического области над диагоналями
    int result = 0;
    int i, j, z;
    for (int i = 0; i < size; i++)
        for (int j = 0; j < size; j++)
            if (((i + j) <= (size + 0)) && (i <= j))
            {
                result += (double) mtx[i][j];
                z = z + 1;
            }
    result /= (double) z;
    return result;
}
Matrix Matrix::Zamena(Matrix ob)
{ //функция сравнения количества положительных и отрицательных элементов
    Matrix result('0' , size); //и замены на большее из них элементов под главной диагональю
    int k = 0;
    int l = 0;
    int i, j;
    for (int i = 0; i <= size; i++)
    {
        for (int j = 0; j <= size; j++)
        {
            if (mtx[i][j] > 0) k = k + 1;
            else l = l + 1;
        }
    }
    for (int i = 0; i <= size; i++)
    {
        for (int j = 0; j < size; j++)
        {
            if (i == j)
            {
                if (k > l)
                {
                    mtx[i][j] = k;
                }
                else mtx[i][j] = l;
            }
        }
        result.mtx[i][j] = mtx[i][j];
        return result;
    }
}
void main()
{
    char ch_fill1;         //выбор заполнения 1 матрицы
    char ch_fill2;         //выбор заполнения 2 матрицы
    char ch_operations;    //выбор операции
    int size;
    setlocale(LC_ALL , "Rus");
    for (;;)
    {
        system("cls");
        Matrix::ChoirOperations(ch_operations); //выбираем операцию над матрицами
        if (ch_operations == '0') break;            //тут выходим, если надо
        cout << "\n";
//узнаем размер матриц
        do
        {
 
            cout << "Vvedite razmer matric: ";
            fflush (stdin);
        } while (scanf("%i" , &size) != 1 || cin.rdbuf()->in_avail() != 1);
        Matrix result; //матрица для хранения результата аримфетических операций
        if (ch_operations > '0' && ch_operations < '4')
        {
            cout << "\nMatrica 1:\n";
            Matrix::ChoirFillMatrix(ch_fill1); //выберем способ заполнения матрицы 1
            Matrix ob(ch_fill1 , size);           //создали 1 матрицу
            cout << "\n";
//показываем и корректируем матрицу 1, если это необходимо
            do
            {
                cout << "Vi vveli matricy 1:\n";
                ob.ShowMatrix();
            } while (ob.CorrectElem());
            cout << "\nMatrica 2:\n";
            Matrix::ChoirFillMatrix(ch_fill2); //выберем способ заполения 2 матрицы
            Matrix ob2(ch_fill2 , size);            //создали 2 матрицу
            cout << "\n";
//показываем и корректируем матрицу 2, если это необходимо
            do
            {
                cout << "Vi vveli matricy 2:\n";
                ob2.ShowMatrix();
            } while (ob2.CorrectElem());
//переходим к реализации арифметических операции
            switch (ch_operations)
            {
                case '1':
                    result = ob.Add(ob2); //сложим матрицы и поместим результат в result
                    cout << "\Rezyltat sloshenia:\n";
                    result.ShowMatrix();           //покажем результат сложения
                    break;
                case '2':
                    result = ob.Sub(ob2); //вычитания матриц и размещение результат в result
                    cout << "\nRezyltat vicitania :\n";
                    result.ShowMatrix();          //показать результат вычитания
                    break;
                case '3':
                    result = ob.Mul(ob2); //умножим матрицы и помести результат в result
                    cout << "\nRezyltat ymnoshenia\n";
                    result.ShowMatrix();    //покажем результат умножения матриц
                    break;
            }      // выбор действий требующих воода только одной матрицы
        }/*else*/
        if (ch_operations >= '4' && ch_operations < '10')
        {
            cout << "\nMatrica :\n";
            Matrix::ChoirFillMatrix(ch_fill1); //выбор способа заполнения матрицы
            Matrix ob(ch_fill1 , size); //создать матрицу с заданными параметрами
 
//показывает и корректирует матрицу, если это требуется
            do
            {
                cout << "\nVi vveli matricy :\n";
                ob.ShowMatrix();
            } while (ob.CorrectElem());
            switch (ch_operations)
            {
                case '4':
                    result = ob.Transp(ob); // транспонируем матрицу и поместим результат в result
                    cout << "\nTransponirovannaya matrica:\n";
 
                    result.ShowMatrix(); // покажем результат транспонирования матриц
                    break;
                case '5':
                    result = ob.Sumtransp(ob); // транспонируем и складываем матрицы и записываем результат в result
                    cout << "\nSumma ishodnoi s tranponirovannoi:\n";
                    result.ShowMatrix();        //выводим получившийся результат
                    break;
                case '6':
                    cout << "\nSrednee arifmetixheskoe elementov nad diagonalyuami:\n";
                    cout << ob.SrAr() << "\n"; //выводим значение среднего арифметического области
                    break;
                case '7':
                    result = ob.Zamena(ob); //выводим матрицу с замененными элементами
                    cout << "\nMatrica s zamenoi:\n";
                    result.ShowMatrix();
                    break;
                case '8':
                    cout << "\nSymma elementov na diagonali: ";
                    cout << ob.SumDiagElements() << "\n"; // выводим сумму диагональных элементов
                    break;
                case '9':
                    cout << "\nSymma vsex elementov: ";
                    cout << ob.SumAllElements() << "\n"; //выводим сумму всех элементов матрицы
                    break;
            }
        }
        cout << "Dlia prodolshenia nashmite lybyiy knopky.";
        getch();
    }
}
Добавлено через 3 минуты
класс матрицы лучше делать шаблоном, как в библиотеках C++
Переписать в шаблон

Добавлено через 2 минуты
а то что вы хотите сделать совсем мне непонятно. Где там может быть наследование? У вас матрица и вы демонстрируете как она работает.
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 09:35  [ТС]     Описание класса матрицы #3
XRuZzz благодарю за то что откликнулись на данную просьбу Я неточно выразился, я имел ввиду не именно наследование, а скажем так "что нибудь добавить" а не просто код C++, давно уже сделал, кто то помог, где то сам, а вот преподаватель не хочет принимать) говорит что только описание класса там, мол видоизмени программу, добавь так сказать еще чего нибудь эдакого, вот и мучаюсь)
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 11:18     Описание класса матрицы #4
перегрузки операторов явно не хватает например +

Добавлено через 4 минуты
например
C++
1
bool operator ==( const Matrix& mat ) const;
C++
1
2
3
4
5
template <class T>
bool Matrixes::operator == ( const Matrixes& mat ) const
{
    return 0 == memcmp(this, &mat, sizeof(Matrixes));
}
может определение детерминанта добавить если у вас его нет

Добавлено через 2 минуты
C++
1
2
        cout << "Viberite odin iz pynktov: ";
        fflush (stdin);
ну если вывод в консоль ещё можно допустить в классе, то ввод лучше внутри класса не делать - это очень не гибко

Добавлено через 1 минуту
Цитата Сообщение от XRuZzz Посмотреть сообщение
int **mtx; //здесь хранится матрица
лучше(удобнее) хранить в std::vector-e, это библиотека STL, но в обучении можно не использовать STL(это уже следующий уровень)
nw
7 / 7 / 0
Регистрация: 25.05.2013
Сообщений: 15
19.06.2013, 11:30     Описание класса матрицы #5
Мне бы, допустим было бы проще разобраться, если бы сам класс был в отдельном файле *.h, а программа в *.cpp
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 12:16     Описание класса матрицы #6
лучше использовать такую структру
в Matrix.h файле - описание класса (причем желательно одного)
в Matrix.cpp - реализация класса
в main.cpp - функция main и использование класса
такой принцип позволяет создавать очень большие проекты

Добавлено через 1 минуту
по ссылке, которую я давал так и сделано, правда шаблоны можно хранить только в h файле вместе с описанием и реализацией.
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 13:24  [ТС]     Описание класса матрицы #7
Прошу прощения, я уже задолбался рыскать по книгам и всемирной паутине Не могу я понять нормально язык C++, как правильно перегрузить операторы, как класс в шаблон записать, лазил, искал и не могу понять. Не сочтите за наглость, но если кому не трудно не могли бы вы на примере моей программы помочь к примеру класс в шаблон записать)
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 14:01     Описание класса матрицы #8
Вы быстрее поймете почитав книгу Deitel "C++ How to program"

Там есть главы и по шаблонам и по перегрузке операторов.

Но если вы не ищите легкий путей, я буду вам подсказывать, но очееень медленно.

добавьте перед вашим классом template <class T>, а так же перед каждой реализацией метода.
Есть какие то вопросы по template <class T>?
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 14:05  [ТС]     Описание класса матрицы #9
Благодарю. Написал, вроде как).. скажем так я вообще это не пойму, программу написал благодаря различным шаблонам, помощи, советам ну и литературы и естественно одним днем не ограничилось все, сейчас бы вот поправить мне, дабы сдать злополучную курсовую, вообщем хотел бы знать что там дальше сделать?
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 14:17     Описание класса матрицы #10
Сообщение было отмечено автором темы, экспертом или модератором как ответ
пример реализации умножения ( у меня этих реализаций матриц, выше крыши, но всё же лучше пользоваться мат. библиотеками C++ )
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
// умножение матриц
CMatrix CMatrix::operator * (const CMatrix &m) const {
  CMatrix nm;
  unsigned w, h;
  if (!this->width || !this->height || !m.width || !m.height) return nm;
  if (this->width != m.height) return nm;
  nm.setSize(this->height, m.width);
  h = nm.height;
  w = nm.width;
  tableitem item;
  for (unsigned i = 0; i < h; i++)
    for (unsigned j = 0; j < w; j++) {
      item = 0;
      for (unsigned k = 0; k < this->width; k++)
        item += this->operator[](i)[k] * m[k][j];
      nm[i][j] = item;
    }
  return nm;
};
Добавлено через 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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
/********************************************************************************
Класс CMatrix, инкапсулирующий основные операции с матрицами.
Данный файл распространяется по принципу AS IS.
Комерческое использование разрешается при условии сохранения данного заголовка.
 
Разработчик: Сергей aka CyBOSSeR Зубов
E-mail: [email]cybosser@gmail.com[/email]
********************************************************************************/
 
#ifndef _MATRIX_
#define _MATRIX_
 
#include <memory.h>
 
class CMatrix
{
private:
    class CRow
    {
    private:
        friend class CMatrix;
 
        CRow(int* pRow, const int nColCount);
        // Указатель на первую ячейку в строке
        int* m_pFirstCellInRow;
        // Количество ячеек в строке
        int m_nRowElementsCount;
    public:
        int &operator[](const int nCellInRow) const;
    };
public:
    CMatrix(const int nRowCount=0, const int nColCount=0);
    CMatrix(const CMatrix &aMatrix);
    ~CMatrix(void);
 
    CRow operator[](const int nRow) const;
    CMatrix operator*(const CMatrix &aMatrix) const;
    CMatrix operator*(const int n) const;
    CMatrix operator+(const CMatrix &aMatrix) const;
    CMatrix operator-(const CMatrix &aMatrix) const;
    CMatrix operator^(const int n) const;
    
    CMatrix& operator=(const CMatrix &aMatrix);
    CMatrix& operator*=(const int n);
    CMatrix& operator*=(const CMatrix &aMatrix);
    CMatrix& operator+=(const CMatrix &aMatrix);
    CMatrix& operator-=(const CMatrix &aMatrix);
    CMatrix& operator^=(const int n);
 
    int GetRowCount(void) const;
    int GetColCount(void) const;
    void Resize(const int nNewRowCount, const int nNewColCount);
private:
    // Количество строк в матрице
    int m_nRowCount;
    // Количество столбцов в матрице
    int m_nColCount;
    // Массив содержащий элементы матрицы
    int *m_pArray;
};
//===============================================================================
// Функции-члены класса CMatrix.
//===============================================================================
CMatrix::CMatrix(const int nRowCount/*=0*/, const int nColCount/*=0*/)
: m_nRowCount(nRowCount)
, m_nColCount(nColCount)
, m_pArray(new int[nRowCount*nColCount])
{ memset(m_pArray, 0, sizeof(int)*m_nRowCount*m_nColCount); }
//-------------------------------------------------------------------------------
CMatrix::CMatrix(const CMatrix &aMatrix)
: m_nRowCount(aMatrix.m_nRowCount)
, m_nColCount(aMatrix.m_nColCount)
, m_pArray(new int[aMatrix.m_nRowCount*aMatrix.m_nColCount])
{ memcpy(m_pArray, aMatrix.m_pArray, sizeof(int)*m_nRowCount*m_nColCount);}
//-------------------------------------------------------------------------------
CMatrix::~CMatrix(void)
{
    if(m_pArray)
        delete [] m_pArray;
}
//-------------------------------------------------------------------------------
// Функция-член, возвращающая объект встроенного класс CRow, служащего для
// доступа к определенной ячейке заданного столбца nRow.
//-------------------------------------------------------------------------------
CMatrix::CRow CMatrix::operator[](const int nRow) const
{ return CRow(m_pArray+nRow*m_nColCount, m_nColCount); }
//-------------------------------------------------------------------------------
// Функция-член перемножения двух матриц.
// В случае, если количество столбцов первой матрицы не равно числу строк второй
// матрицы, возвращается пустая матрица размером 0x0.
//-------------------------------------------------------------------------------
CMatrix CMatrix::operator*(const CMatrix &aMatrix) const
{
    CMatrix tmpMatrix(*this);
 
    tmpMatrix *= aMatrix;
 
    return tmpMatrix;
}
//-------------------------------------------------------------------------------
// Функция-член умножения матрицы на заданное число n.
//-------------------------------------------------------------------------------
CMatrix CMatrix::operator*(const int n) const
{
    CMatrix tmpMatrix(*this);
 
    tmpMatrix *= n;
 
    return tmpMatrix;
}
//-------------------------------------------------------------------------------
// Функция-член сложения двух матриц.
//-------------------------------------------------------------------------------
CMatrix CMatrix::operator+(const CMatrix &aMatrix) const
{
    CMatrix tmpMatrix(*this);
 
    tmpMatrix += aMatrix;
 
    return tmpMatrix;
}
//-------------------------------------------------------------------------------
// Функция-член разности двух матриц.
//-------------------------------------------------------------------------------
CMatrix CMatrix::operator-(const CMatrix &aMatrix) const
{
    CMatrix tmpMatrix(*this);
 
    tmpMatrix -= aMatrix;
 
    return tmpMatrix;
}
//-------------------------------------------------------------------------------
// Функция-член возведения матрицы в натуральную степень n.
//-------------------------------------------------------------------------------
CMatrix CMatrix::operator^(const int n) const
{
    CMatrix tmpMatrix(*this);
 
    tmpMatrix ^= n;
 
    return tmpMatrix;
}
//-------------------------------------------------------------------------------
// Функция-член домножения матрицы на другую матрицу.
// В случае, если количество столбцов первой матрицы не равно числу строк второй
// матрицы, исходная матрица преобразуется в матрицу размером 0x0.
//-------------------------------------------------------------------------------
CMatrix& CMatrix::operator*=(const CMatrix &aMatrix)
{
    if(m_nColCount != aMatrix.m_nRowCount)
    {
        Resize(0, 0);
        return *this;
    }
 
    CMatrix tmpMatrix(m_nRowCount, aMatrix.m_nColCount);
 
    for(int i=0; i<tmpMatrix.m_nRowCount; i++)
        for(int j=0; j<tmpMatrix.m_nColCount; j++)
            for(int k=0; k<m_nColCount; k++)
                tmpMatrix[i][j]+=(*this)[i][k]*aMatrix[k][j];
 
    (*this) = tmpMatrix;
 
    return *this;
}
//-------------------------------------------------------------------------------
// Функция-член домножения матрицы на заданное число n.
//-------------------------------------------------------------------------------
CMatrix& CMatrix::operator*=(const int n)
{
    int nLenghtOfArray = m_nRowCount * m_nColCount;
 
    for(int i=0; i<nLenghtOfArray; i++)
        m_pArray[i] *= n;
 
    return *this;
}
//-------------------------------------------------------------------------------
// Функция-член сложения матрицы с другой матрицой.
// В случае, если матрицы имеют различную размерность, функция преобразует
// исходную матрицу в матрицу размерностью 0x0.
//-------------------------------------------------------------------------------
CMatrix& CMatrix::operator+=(const CMatrix &aMatrix)
{
    if(m_nRowCount != aMatrix.m_nRowCount || m_nColCount != aMatrix.m_nColCount)
    {
        Resize(0, 0);
        return *this;
    }
 
    int nLenghtOfArray = m_nRowCount * m_nColCount;
 
    for(int i=0; i<nLenghtOfArray; i++)
        m_pArray[i] += aMatrix.m_pArray[i];
 
    return *this;
}
//-------------------------------------------------------------------------------
// Функция-член вычитания матрицы aMatrix из текущей.
//-------------------------------------------------------------------------------
CMatrix& CMatrix::operator-=(const CMatrix &aMatrix)
{
    if(m_nRowCount != aMatrix.m_nRowCount || m_nColCount != aMatrix.m_nColCount)
    {
        Resize(0,0);
        return *this;
    }
 
    int nLenghtOfArray = m_nRowCount * m_nColCount;
 
    for(int i=0; i<nLenghtOfArray; i++)
        m_pArray[i] -= aMatrix.m_pArray[i];
 
    return *this;
}
//-------------------------------------------------------------------------------
// Функция-член возведения матрицы в натуральную степень n.
//-------------------------------------------------------------------------------
CMatrix& CMatrix::operator^=(const int n)
{
    CMatrix tmpMatrix(*this);
 
    for(int i=1; i<n; i++)
        (*this) *= tmpMatrix;
 
    return *this;
}
//-------------------------------------------------------------------------------
// Функция-член присваивания.
//-------------------------------------------------------------------------------
CMatrix& CMatrix::operator=(const CMatrix &aMatrix)
{
    if(this==&aMatrix)
        return *this;
 
    if(m_pArray)
        delete [] m_pArray;
 
    m_nRowCount = aMatrix.m_nRowCount;
    m_nColCount = aMatrix.m_nColCount;
 
    m_pArray = new int[m_nRowCount*m_nColCount];
 
    memcpy(m_pArray, aMatrix.m_pArray, sizeof(int)*m_nRowCount*m_nColCount);
 
    return *this;
}
//-------------------------------------------------------------------------------
// Функция-член получения количества строк матрицы.
//-------------------------------------------------------------------------------
inline int CMatrix::GetRowCount(void) const
{ return m_nRowCount; }
//-------------------------------------------------------------------------------
// Функция-член получения количества столбцов матрицы.
//-------------------------------------------------------------------------------
inline int CMatrix::GetColCount(void) const
{ return m_nColCount; }
//-------------------------------------------------------------------------------
// Функция-член изменения размеров матрицы.
//-------------------------------------------------------------------------------
void CMatrix::Resize(const int nNewRowCount, const int nNewColCount)
{
    if(m_pArray)
        delete [] m_pArray;
 
    m_nRowCount = nNewRowCount;
    m_nColCount = nNewColCount;
 
    m_pArray = new int[m_nRowCount*m_nColCount];
    
    memset(m_pArray, 0, sizeof(int)*m_nRowCount*m_nColCount);
}
//===============================================================================
// Функции-члены класс CMatrix::CRow.
//===============================================================================
CMatrix::CRow::CRow(int *pRow, const int nColCount)
: m_pFirstCellInRow(pRow)
, m_nRowElementsCount(nColCount)
{}
//-------------------------------------------------------------------------------
// Оператор возвращающий требуемую ячейку в строке. 
//-------------------------------------------------------------------------------
int &CMatrix::CRow::operator [](const int nCellInRow) const
{ 
    return (nCellInRow < m_nRowElementsCount)? m_pFirstCellInRow[nCellInRow]:
                                               m_pFirstCellInRow[0];
}
//-------------------------------------------------------------------------------
 
#endif
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 14:21  [ТС]     Описание класса матрицы #11
Я выставил template <class T> перед классом и методами, а нельзя ли как нибудь ускорить процесс, просто сдача курсовой через пару часов..) завтра еще экзамен сдавать к сожалению.. такой вот студент ленивый
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 14:29     Описание класса матрицы #12
К сожалению я не такой опытный препод, например как Дейтелы. Врятли мне удастся объяснить вам материал быстрее чем они )
Посмотрите внимательно на ваш исходник и подумайте чего не хватает для реализации шаблона.

Понятно, что означает T? в конструкции template <class T>?

Добавлено через 2 минуты
но может есть смысл не терять времени на шаблоны. Ведь они нужны, чтоб научить класс матрицы работать с разными типами, например int, double и т п
ограничиться перегрузкой операторов.
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 14:31  [ТС]     Описание класса матрицы #13
Может вы и правы, но ведь я то программу вот так сказать сделал, мне лишь надо добавить элементы ООП( Обьектно-ориентированного программирования), иными словами.. я приделаю к проге все что можно уже) мне лишь бы курсач сдать... и шаблоны.. и перегрузку операторов и т.д. видоизменить код программы надо, а у меня только описание класса там идет
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 14:40     Описание класса матрицы #14
Для демонстрации знаний принципов ООП вам действительно не хватает наследования, и полиморфизма. Но я в упор не понимаю зачем тут нужно применять наследование и виртуальные методы. Вам для начала нужно придумать предметную область.

Но если делать тупо то для полиморфизма можно определить класс
IMatrix
в который добавить виртуальные функции

а класс Matrix сделать родителем кого-нибудь другого класс, который расширяет возможности этого класса.
вот кстати вместо шаблонов можно реализовать IntMatrix RealMatrix, которые будут наследниками интерфейсного класса IMatrix. Но это потребует от вас высокой скорости написания кода.

Тем более если не умеете пользоваться виртуальными методами то быстро в них очень сложно разобраться.

Помоему вам капец
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 14:43  [ТС]     Описание класса матрицы #15
Благодарю вас за помощь и за время которое уделили, попробую что нибудь сделать)
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 14:47     Описание класса матрицы #16
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Создайте потомка Матрицы и делайте тупое наследование

Например MagicMatrix

C++
1
2
3
4
class MagicMatrix: public Matrix
{
...
}
и добавьте там один метод
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
/**
    Определить является ли матрица магическим квадратом
*/
bool MagicMatrix::isMagic(int (&matrix)[rows][cols])
{
    if (n != m) return false;
    int first_row_sum = 0;
    for (size_t i = 0; i < cols; i++)
        first_row_sum += matrix[0][i];
 
    for (size_t i = 1; i < rows; i++)
    {
        int temp_sum = 0;
        for (size_t j = 0; j < cols; j++)
            temp_sum += matrix[i][j];
        if (temp_sum != first_row_sum)
            return false;
    }
 
    for (size_t i = 0; i < cols; i++)
    {
        int temp_sum = 0;
        for (size_t j = 0; j < rows; j++)
            temp_sum += matrix[j][i];
        if (temp_sum != first_row_sum)
            return false;
    }
    return true;
}
а про полиморфизм, говорите, что много читали, но так и не поняли сути. Вам поверят.
Msstitel
0 / 0 / 0
Регистрация: 19.06.2013
Сообщений: 8
19.06.2013, 14:51  [ТС]     Описание класса матрицы #17
Интересненько... что ж попробую)) если сдам курсач.. обязательно скажу)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.06.2013, 14:59     Описание класса матрицы
Еще ссылки по теме:

C++ Составить описание класса, обеспечивающего представление матрицы произвольного размера
C++ Нужен пример описания любого класса
C++ Как вынести описание методов вложенного класса за пределы класса?

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

Или воспользуйтесь поиском по форуму:
XRuZzz
19.06.2013, 14:59     Описание класса матрицы
  #18

Не по теме:

обратите внимание под каждым сообщением есть кнопки "цитата" и другие полезные кнопки...

Yandex
Объявления
19.06.2013, 14:59     Описание класса матрицы
Ответ Создать тему

Метки
операции с матрицами c++, операции с матрицами
Опции темы

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