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

Составить описание класса для определения квадратных матриц целых чисел - C++

Восстановить пароль Регистрация
 
Oksana fiz
0 / 0 / 0
Регистрация: 06.12.2012
Сообщений: 4
06.12.2012, 15:16     Составить описание класса для определения квадратных матриц целых чисел #1
Реализация класса для работы с матрицами целых чисел.

Задание: Составить описание класса для определения квадратных матриц целых чисел. Обеспечить выполнение операций над матрицами: слоение, вычитание, умножение, транспонирование, умножение элементов матриц на скаляр. Предусмотреть вывод отдельных элементов и самих матриц на экран.

Понимаю, что много раз звучала подобные темы, но никак самой не получается составить в силу неопытности. Помогите, пожалуйста.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.12.2012, 15:16     Составить описание класса для определения квадратных матриц целых чисел
Посмотрите здесь:

Описание класса для определения одномерных массивов строк фиксированной длины C++
C++ Составить программу определения минимального среди 5 введенных целых чисел.
C++ Составить описание класса для представления комплексных чисел
C++ Составить описание класса для представления комплексных чисел
C++ Составить описание класса для определения одномерных массивов
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.12.2012, 15:20     Составить описание класса для определения квадратных матриц целых чисел #2
Посмотрите в поиске или например здесь Класс Matrix, Перегрузка
Oksana fiz
0 / 0 / 0
Регистрация: 06.12.2012
Сообщений: 4
06.12.2012, 15:29  [ТС]     Составить описание класса для определения квадратных матриц целых чисел #3
Спасибо, что откликнулись.
Я облазила весь интернет.
Находила бесчисленное кол-во аналогичных задач, включая Вашу, но никак в свою переделать не могу. Единственное, что смогла набрать - это отдельные части программы для квадратных матриц
А именно:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
using namespace std;
class QMatrix : public Matrix 
{
public:
      QMatrix();
      QMatrix(int);
      ~QMatrix();
};
QMatrix::QMatrix(int n1)
{
    n=n1;
    m=n1;
    a=new double* [m];
    for (int i=0;i<m;i++)
        a[i] = new double [n];
    for (int i=0;i<m;i++)
        for (int j=0;j<n;j++)
            a[i][j]=0.0;
            }
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.12.2012, 15:34     Составить описание класса для определения квадратных матриц целых чисел #4
В той ссылке, которую я вам дал, в посте номер 7, почти всё реализовано из ваших условий, может кроме транспонирования. Возьмите код из ссылки за основу и добавьте не хватающие операции.
Oksana fiz
0 / 0 / 0
Регистрация: 06.12.2012
Сообщений: 4
06.12.2012, 15:58  [ТС]     Составить описание класса для определения квадратных матриц целых чисел #5
Добавлено через 1 минуту
Спасибо огромное.

Попытаюсь разобраться.

А в этой программе " вывод отдельных элементов и самих матриц на экран" предусмотрено?
David Sylva
 Аватар для David Sylva
1281 / 943 / 51
Регистрация: 17.05.2012
Сообщений: 2,686
06.12.2012, 16:00     Составить описание класса для определения квадратных матриц целых чисел #6
Цитата Сообщение от Oksana fiz Посмотреть сообщение
А в этой программе " вывод отдельных элементов и самих матриц на экран" предусмотрено?
Да. конечно.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.12.2012, 11:50     Составить описание класса для определения квадратных матриц целых чисел
Еще ссылки по теме:

Составить описание класса для представления комплексных чисел C++
Составить описание класса для представления комплексных чисел C++
Описание класса для определения одномерных массивов строк. Исправить ошибку C++

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

Или воспользуйтесь поиском по форуму:
Oksana fiz
0 / 0 / 0
Регистрация: 06.12.2012
Сообщений: 4
07.12.2012, 11:50  [ТС]     Составить описание класса для определения квадратных матриц целых чисел #7
Пыталась модифицировать Вашу программу для моего случая. Ошибок, конечно, много. Посмотрите пожалуйста, что я удалила лишнее. И я не понимаю какую роль играют конструкторы по умолчанию, констр. с параметрами, констр. копии, деструкторы и нужны ли они мне. А после "int main()" вводятся параметра конкретного случая? И нужны ли мне 9-12 строки?
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
#include <iostream>
#include <cstdlib> 
#include <ctime> 
#include <iomanip>
 
class QMatrix 
{ 
private: 
    int N; 
    int M; 
    double** matrix; 
public:  
    QMatrix(); // ГЄГ®Г*ñòðóêòîð ГЇГ® óìîë÷Г*Г*ГЁГѕ
    QMatrix(int n):Matrix(n,n) // ГЄГ®Г*ñòðóêòîð Г± ГЇГ*Г°Г*ìåòðГ*ìè
    QMatrix(const Matrix& ob) // ГЄГ®Г*ñòðóêòîð êîïèè
    ~QMatrix() // äåñòðóêòîð 
    void Enter() 
    void Show() 
    QMatrix operator + (const Matrix&) 
    QMatrix operator = (const Matrix&) 
    QMatrix operator - (const Matrix& ) 
    QMatrix operator * (const Matrix& )  
}  
  
QMatrix::QMatrix() // ðåГ*ëèçГ*öèÿ ГЄГ®Г*ñòðóêòîðГ* ГЇГ® óìîë÷Г*Г*ГЁГѕ
{ 
      N = 0; M = 0; 
        matrix = new double*[N]; 
        for ( int i = 0; i < N; ++i) 
            matrix[i] = new double[M]; 
} 
 
QMatrix:: QMatrix(int n1) // ðåГ*ëèçГ*öèÿ ГЄГ®Г*ñòðóêòîðГ* Г± ГЇГ*Г°Г*ìåòðГ*ìè
{
    N = n1;
    M = n1; 
    a=new double* [M];
    for (int i=0;i<M;i++)
        a[i] = new double [N];
    for (int i=0;i<M;i++)
        for (int j=0;j<N;j++)
            a[i][j]=0.0;    
                    
} 
 
QMatrix::QMatrix (const Matrix &ob) // ðåГ*ëèçГ*öèÿ ГЄГ®Г*ñòðóêòîðГ* êîïèè
{   
    N = ob.N; 
    M = ob.M;
    matrix = new double*[N]; 
    for ( int i = 0; i < N; ++i) 
        matrix[i] = new double[M];  
 
    for ( int i = 0; i < N; ++i) 
        for ( int j = 0; j < M; ++j) 
            matrix[i][j] = ob.matrix[i][j];
 
}  
 
QMatrix::~QMatrix() // äåñòðóêòîð
{  
    for ( int i = 0; i < N; ++i) 
        delete[] matrix[i]; 
    delete[] matrix;
}
 
void QMatrix::Enter() // ââîä Г¬Г*òðèö
{   
    int i, j;
    for ( i = 0; i < N; ++i) 
        for ( j = 0; j < M; ++j) 
            matrix[i][j] = 0.01 * (rand() % 1001);
 
} 
 
void Matrix::Show() // âûâîä Г¬Г*òðèöû
{ 
    int i, j; 
 
    for ( i = 0; i < N; ++i) 
        for ( j = 0; j < M; ++j) 
        { 
            if( j % M == 0) 
                std::cout << std::endl; 
            std::cout << std::setw(10) << matrix[i][j]; 
        } 
        std::cout << std::endl;
} 
 
QMatrix QMatrix :: operator + ( const Matrix& ob) // ñóììГ* Г¬Г*òðèö
{  
    QMatrix temp;                        // ðåГ*ëèçîâГ*Г*Г® Г± ïîìîùüþ âðåìåГ*Г*îãî îáúåêòГ*
    temp.N = this->N; 
    temp.M = this->M; 
    int i, j;
    temp.matrix = new double*[temp.N]; 
    for ( i = 0; i < temp.N; ++i) 
        temp.matrix[i] = new double[temp.M]; 
 
    for ( i = 0; i < temp.N; ++i) 
        for ( j = 0; j < temp.M; ++j) 
            temp.matrix[i][j] = this->matrix[i][j] + ob.matrix[i][j]; 
    return temp;
 
} 
  
QMatrix QMatrix::operator - (const Matrix& ob) // Г°Г*Г§Г*îñòü Г¬Г*òðèö
{ 
    int i, j; 
    for ( i = 0; i < this->N; ++i) 
        for ( j = 0; j < this->M; ++j) 
            this->matrix[i][j] = this->matrix[i][j] - ob.matrix[i][j]; 
    return *this;
} 
 
QMatrix QMatrix::operator * (const Matrix& ob) // ГіГ¬Г*îæåГ*ГЁГҐ Г¬Г*òðèö
{   
 
    
    QMatrix temp; 
    temp.N = this->N; 
    temp.M = this->M; 
    int i, j, k;
    temp.matrix = new double*[temp.N]; 
    for ( i = 0; i < temp.N; ++i) 
        temp.matrix[i] = new double[temp.M];
 
    for ( i = 0; i < temp.N; ++i) 
        for ( j = 0; j < temp.M; ++j) 
        {   
            temp.matrix[i][j] = 0;
            for ( k = 0; k < temp.M; ++k)     
               temp.matrix[i][j] = temp.matrix[i][j] + (this->matrix[i][k] * ob.matrix[k][j]); 
        }
    return temp; 
}
 
 
int main() 
{   
    srand((unsigned) time(0));
    QMatrix m1(3, 3); 
    m1.Enter(); 
    m1.Show(); 
    QMatrix m2(3, 3); 
    m2.Enter();
    m2.Show();
    QMatrix m3(3,3); 
    m3 = m1 * m2;
    m3.Show();
    
}
Yandex
Объявления
07.12.2012, 11:50     Составить описание класса для определения квадратных матриц целых чисел
Ответ Создать тему

Метки
задач
Опции темы

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