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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Построить график в С++ http://www.cyberforum.ru/cpp-beginners/thread906291.html
Нужно построить в С++, один любой график из 7 функций. Помогите пожалуйста, срочно!
C++ Ошибка в коде В чем проблема? Подскажите! Она меня уже из себя выводит! Выдает: 1>d:\политех\iisemstr\lab_01\proffpicode\proffpicode\proffpicode.cpp(200): warning C4101: outfunc: неиспользованная локальная переменная 1>d:\политех\iisemstr\lab_01\proffpicode\proffpicode\proffpicode.cpp(239): warning C4101: outfunc: неиспользованная локальная переменная... http://www.cyberforum.ru/cpp-beginners/thread906288.html
C++ Сортировка текстового файла
Крошка сын к отцу пришел... а точнее дочка- первокурсница, с просьбой - Папа, помоги! Ну, папа бы и рад помочь, но программирование изучал в 1994 году на первом курсе, да и то FORTRAN IV. Так что, я подумал, мои знания из 1994 года тут вряд ли помогут. Но не обязательно все знать, главное - знать, где можно узнать. А теперь, собственно, вопрос: -Даны текстовый файл F. Группы...
C++ Ошибка в проге
Дан файл с непустой последовательностью слов, содержащих от 1 до 8 букв. Напечатать все слова наименьшей длины. #include "stdafx.h" #include <iostream> #include <fstream> #include "stdio.h" using namespace std; int main() {
C++ Ошибка в коде программы(Классы) http://www.cyberforum.ru/cpp-beginners/thread906220.html
Собственно вод код #include "stdafx.h" #include <conio.h> #include <string.h> #include <iostream> using namespace std; struct date // vrem9 poleta { double time; };
C++ Определить количество символов В содержащихся в строке Заданная строка. Определить количество символов В содержащихся в этой строке. подробнее

Показать сообщение отдельно
XRuZzz
Антикодер
577 / 478 / 23
Регистрация: 15.09.2012
Сообщений: 2,429
19.06.2013, 09:31     Описание класса матрицы
ппц я думал там целый проект, а там всего один исходник, помогу для начала автоматическим форматированием, чтоб другие не мучались с вашим кодом.

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 минуты
а то что вы хотите сделать совсем мне непонятно. Где там может быть наследование? У вас матрица и вы демонстрируете как она работает.
 
Текущее время: 14:24. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru