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

Класс Матрица - C++

Восстановить пароль Регистрация
 
PandaDa
0 / 0 / 0
Регистрация: 11.05.2010
Сообщений: 3
11.05.2010, 10:59     Класс Матрица #1
Ребят, помогите с прогой!
Определить класс матрица. В класс включить два конструктора: создание матрицы по количеству столбцов и строк и конструктор-копия. Определить функции-члены: вывод на экран элементов матрицы.
Перегрузить оператор: ++ нахождения среднеарифметического среди элементов главной диагонали.

Пока пытаюсь написать только для 1ого конструктора, но все тщетно.
Помогите исправить ошибки, кому несложно!

Добавлено через 34 секунды
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
// Lab5_Task1.cpp: определяет точку входа для консольного приложения.
//
 
#include <stdafx.h>
#include <iostream> 
#include <iomanip>
#include <math.h>
#include <time.h>
 
using   namespace std;
 
class Matrix
{
protected:
    int m,n;
    int **a;
public:
    Matrix(int **a,int m, int n);
    void Output(int **a, int m, int n);
}
 
Matrix::Matrix()
       {
        srand((unsigned)time(NULL)); 
        int **a=new int*[n];
        for(int i=0;i<m;i++)
            {
                a[i]=new int [m];
                for(int j=0;j<n;j++)    
                a[i][j]=rand()/100-100;
            
            }
    }
 
void Matrix::Output(int **a, int m, int n)
{
    cout<<"Введите количество строк: ";
    cin>>m;
    cout<<"Введите количество столбцов: ";
    cin>>n;
    for(int i=0;i<m;i++)
        {
                  for(int j=0;j<n;j++)  cout<<setw(6)<<a[i][j];
                  cout<<endl;
        }
}
 
int main()
{
    setlocale(LC_CTYPE,"Russian");
    Matrix X;
    X.Output;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.05.2010, 10:59     Класс Матрица
Посмотрите здесь:

Класс Матрица C++
с++ класс матрица C++
Класс матрица C++
Класс матрица C++
C++ Класс матрица
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Crudelis
Шаровик затейник
 Аватар для Crudelis
667 / 409 / 13
Регистрация: 06.05.2010
Сообщений: 1,109
11.05.2010, 14:25     Класс Матрица #2
Цитата Сообщение от PandaDa Посмотреть сообщение
a[i][j]=rand()/100-100;
первое что заметил
a[i][j]=rand()%100-100;

Добавлено через 1 минуту
Цитата Сообщение от PandaDa Посмотреть сообщение
Matrix X;
Matrix (X);
з.ы. непонятно в программе что такое Х

Добавлено через 1 минуту
Цитата Сообщение от PandaDa Посмотреть сообщение
X.Output;
Output(a,m,n);

Добавлено через 2 минуты
у вас в main фактически ничего нет, перенесите туда массив, непонятно как вы в Output собираетесь передавать массив
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
11.05.2010, 23:14     Класс Матрица #3
Вот старался, сделал класс матрицы, может кому пригодиться..
Надеюсь ошибок нет.

Класс матрицы
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
#include <iostream>
using namespace std;
//Класс матрицы.
class CMatrix {
protected:
int **d_ptr;     //указатель на начало матрицы.
int H;  //высота.
int W;  //ширина.
 
public:
CMatrix(unsigned int H_I, unsigned int W_I );                    
CMatrix(unsigned int H_I, unsigned int W_I , int copy_val);        //монотонная инициализация.
CMatrix(const CMatrix& ptr);  //копировщик.
const CMatrix& operator = (const CMatrix& ptr);  //операция присваивания.
virtual ~CMatrix();           //деструктор.
//Дополнительные функции.
long Show();        //показать матрицу.
long Input();       //заполнить матрицу.
inline void GetSParam(int &H_I, int &W_I) const {H_I = H; W_I = W; }
 
CMatrix& operator ++ ();
CMatrix  operator ++ (int);
CMatrix& operator -- ();
CMatrix  operator -- (int);
 
CMatrix &operator += (const CMatrix& ptr);
CMatrix &operator -= (const CMatrix& ptr);
CMatrix operator + (const CMatrix& ptr);
 
//Индексация без проверки, она все равно сильно не поможет, потому как вторая  [] делаетсся в клиенте.
int *operator [](int index_H){ return d_ptr[index_H]; }
 
float SAR();                    //находит средее арифметическое.
};
 
//Реализации секции public:
CMatrix::CMatrix(unsigned int H_I, unsigned int W_I ){
H  = H_I;           
W  = W_I;
//--------------------------------------------------
//Выделили память.
d_ptr = new int *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new int[W];
//--------------------------------------------------
//Заполнилил случайными числами.
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r] = rand()%10;
} 
//монотонная инициализация.
CMatrix::CMatrix(unsigned int H_I, unsigned int W_I , int copy_val){
H  = H_I;           
W  = W_I;
//--------------------------------------------------
//Выделили память.
d_ptr = new int *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new int[W];
//--------------------------------------------------
//Заполнилил числом.
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r] = copy_val;
}
 
//копировщик.
CMatrix::CMatrix(const CMatrix& ptr){ 
H = ptr.H;
W = ptr.W;
//Выделили память.
d_ptr = new int *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new int[W];
//--------------------------------------------------
//Копировали матрицу:
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r]=ptr.d_ptr[p][r];
}
//деструктор.
CMatrix::~CMatrix(){
for( int i = 0 ; i < H ; i++ )delete[]d_ptr[i]; 
delete []d_ptr;
}
 
//Операция присваивания.
const CMatrix& CMatrix::operator = (const CMatrix& ptr){
if(&ptr==this)return *this; //проверка на самоприсваивание.
//ОСвободили память.
for( int k = 0 ; k < H ; k++ )delete[]d_ptr[k]; 
delete []d_ptr;
H = ptr.H;
W = ptr.W;
 
//Выделили память.
d_ptr = new int *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new int[W];
//--------------------------------------------------
//Копировали матрицу:
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r]=ptr.d_ptr[p][r];
return *this;
}
 
 
//Дополнительные функции.
//показать матрицу.
long CMatrix::Show(){
    for(int i = 0 ; i < H ; i++ ){
        for(int j = 0 ; j < W ; j++ ){
        cout<<' '<<d_ptr[i][j];
        }
cout<<endl;  
    }
cout<<endl;  
return 0;
}
//заполнить матрицу.
long CMatrix::Input(){
    for(int i = 0 ; i < H ; i++ ){
        for(int j = 0 ; j < W ; j++ ){
        cout<<'['<<i<<']'<<'['<<j<<']'<<' ';cin>>d_ptr[i][j];
        }
cout<<endl;  
    }
cout<<endl;     
 
return 0;
}
 
//находит средее арифметическое.
float CMatrix::SAR(){
float sum = 0.0f; 
        for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )sum+=d_ptr[i][j];
return (sum/(H*W));
}
 
CMatrix& CMatrix::operator ++ (){
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]++;
return *this;
 
}
 
CMatrix CMatrix::operator ++ (int){
CMatrix obj(*this);      //копировщик
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]++;
return obj;
}
 
CMatrix& CMatrix::operator -- (){
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]--;
return *this;
}
CMatrix  CMatrix::operator -- (int){
CMatrix obj(*this);      //копировщик
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]--;
return obj;
}
 
CMatrix & CMatrix::operator += (const CMatrix& ptr){
if(ptr.H!=H||ptr.W!=W)return *this;
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]+=ptr.d_ptr[i][j];
return *this;
}
 
CMatrix & CMatrix::operator -= (const CMatrix& ptr){
if(ptr.H!=H||ptr.W!=W)return *this;
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]-=ptr.d_ptr[i][j];
return *this;
}
 
 
CMatrix CMatrix::operator + (const CMatrix& ptr){
CMatrix obj(*this);      //копировщик
if(ptr.H!=H||ptr.W!=W)return obj;
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )obj.d_ptr[i][j]+=ptr.d_ptr[i][j];
return obj;
}
 
 
 
//Клиентская часть:
int main(){
 
CMatrix matrix_1(10,10);      //работает конструктор.
CMatrix matrix_2 = matrix_1;  //вызываеться контруктор копирования.
matrix_1.Show();
 
matrix_2++;
matrix_2.Show();
 
cout<<"SAR Matrix_1: "<<matrix_1.SAR()<<endl;
cout<<"SAR Matrix_2: "<<matrix_2.SAR()<<endl;
CMatrix matrix_3(10,10,0);
 
cout<<endl;
matrix_3 = matrix_1 + matrix_2;
matrix_3.Show();
cout<<"SAR Matrix_3: "<<matrix_3.SAR()<<endl;
cout<<endl;
 
matrix_3[9][9] = 777;
matrix_3.Show();
return 0;
}


++ для среднего арифметического это глупость.
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
16.05.2010, 23:35     Класс Матрица #4
Класс матрицы_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
#include <iostream>
#include <time.h>
using namespace std;
 
//Класс матрицы.
template<class T>
class CMatrix {
protected:
T **d_ptr;     //указатель на начало матрицы.
int H;  //высота.
int W;  //ширина.
 
public:
CMatrix(unsigned int H_I, unsigned int W_I );                    
CMatrix(unsigned int H_I, unsigned int W_I , int copy_val);        //монотонная инициализация.
CMatrix(const CMatrix<T>& ptr);  //копировщик.
const CMatrix<T>& operator = (const CMatrix<T>& ptr);  //операция присваивания.
virtual ~CMatrix();              //деструктор.
 
inline void GetSParam(int &H_I, int &W_I) const {H_I = H; W_I = W; }
 
CMatrix<T>& operator ++ ();
CMatrix<T>  operator ++ (int);
CMatrix<T>& operator -- ();
CMatrix<T>  operator -- (int);
 
CMatrix<T> &operator += (const CMatrix<T>& ptr);
CMatrix<T> &operator -= (const CMatrix<T>& ptr);
CMatrix<T> operator + (const CMatrix<T>& ptr);
 
//Индексация без проверки, она все равно не поможет, потому как вторая  [] делаетсся в клиенте.
T *operator [](int index_H){ return d_ptr[index_H]; }
 
long Show();
long Input();
 
 
};
 
//Реализации секции public:
template<class T>
CMatrix<T>::CMatrix(unsigned int H_I, unsigned int W_I ){
H  = H_I;           
W  = W_I;
//--------------------------------------------------
//Выделили память.
d_ptr = new T *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new T[W];
//--------------------------------------------------
srand((unsigned)time(NULL)); 
//Заполнили случайными числами.
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r] = rand()%10;
} 
 
//монотонная инициализация.
template<class T>
CMatrix<T>::CMatrix(unsigned int H_I, unsigned int W_I , int copy_val){
H  = H_I;           
W  = W_I;
//--------------------------------------------------
//Выделили память.
d_ptr = new T *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new T[W];
//--------------------------------------------------
//Заполнилил числом.
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r] = copy_val;
}
 
//копировщик.
template<class T>
CMatrix<T>::CMatrix(const CMatrix<T>& ptr){ 
H = ptr.H;
W = ptr.W;
//Выделили память.
d_ptr = new T *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new T[W];
//--------------------------------------------------
//Копировали матрицу:
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r]=ptr.d_ptr[p][r];
}
//деструктор.
template<class T>
CMatrix<T>::~CMatrix(){
for( int i = 0 ; i < H ; i++ )delete[]d_ptr[i]; 
delete []d_ptr;
}
 
//Операция присваивания.
template<class T>
const CMatrix<T>& CMatrix<T>::operator = (const CMatrix<T>& ptr){
if(&ptr==this)return *this; //проверка на самоприсваивание.
//ОСвободили память.
for( int k = 0 ; k < H ; k++ )delete[]d_ptr[k]; 
delete []d_ptr;
H = ptr.H;
W = ptr.W;
 
//Выделили память.
d_ptr = new T *[H];
for( int i = 0 ; i < H ; i++ )d_ptr[i] = new T[W];
//--------------------------------------------------
//Копировали матрицу:
for( int p = 0 ; p < H ; p++ )for( int r = 0 ; r < W ; r++)d_ptr[p][r]=ptr.d_ptr[p][r];
return *this;
}
 
template<class T>
CMatrix<T>& CMatrix<T>::operator ++ (){
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]++;
return *this;
 
}
template<class T>
CMatrix<T> CMatrix<T>::operator ++ (int){
CMatrix <T>obj(*this);    
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]++;
return obj;
}
template<class T>
CMatrix<T>& CMatrix<T>::operator -- (){
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]--;
return *this;
}
template<class T>
CMatrix<T> CMatrix<T>::operator -- (int){
CMatrix <T>obj(*this);     
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]--;
return obj;
}
template<class T>
CMatrix<T>& CMatrix<T>::operator += (const CMatrix<T>& ptr){
if(ptr.H!=H||ptr.W!=W)return *this;
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]+=ptr.d_ptr[i][j];
return *this;
}
template<class T>
CMatrix<T>& CMatrix<T>::operator -= (const CMatrix<T>& ptr){
if(ptr.H!=H||ptr.W!=W)return *this;
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )d_ptr[i][j]-=ptr.d_ptr[i][j];
return *this;
}
 
template<class T>
CMatrix<T> CMatrix<T>::operator + (const CMatrix<T>& ptr){
CMatrix<T>obj(*this);      
if(ptr.H!=H||ptr.W!=W){ CMatrix<T>t(H,W,-1); return t; }
for(int i = 0 ; i < H ; i++ )for(int j = 0 ; j < W ; j++ )obj.d_ptr[i][j]+=ptr.d_ptr[i][j];
return obj;
}
 
template<class T>
long CMatrix<T>::Show(){
    for(int i = 0 ; i < H ; i++ ){
        for(int j = 0 ; j < W ; j++ ){
        cout<<' '<<d_ptr[i][j];
        }
cout<<endl;  
    }
cout<<endl;  
return 0;
}
template<class T>
long CMatrix<T>::Input(){
for( int i = 0 ; i < H ; i++ ){
        for( int j = 0; j < W ; j++){
        cout<<"Input :"<<'['<<i<<']'<<'['<<j<<']'<<' '; cin>>d_ptr[i][j];      
        }
    }
cout<<endl;
 
return 0;
}
 
 
//Клиентская часть:
int main(){
CMatrix<double>matrix_1(5,5);      
CMatrix<double>matrix_2 = matrix_1; 
matrix_1.Show();
matrix_2++;
matrix_2.Show();
CMatrix <double>matrix_3(5,5,0);
matrix_3 = matrix_1 + matrix_2;
matrix_3.Show();
matrix_3[2][2] = 70.5;
matrix_3.Show();
return 0;
}
stv
26 / 26 / 6
Регистрация: 05.03.2010
Сообщений: 171
19.05.2010, 17:28     Класс Матрица #5
При перегрузке оператора присваивания нужно освобождать память матрицы, значение которой было присвоено, или деструктор освободит ее?
Genius Ignat
1233 / 771 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
19.05.2010, 17:48     Класс Матрица #6
нужно освобождать память матрицы

Конечно.
Yandex
Объявления
19.05.2010, 17:48     Класс Матрица
Ответ Создать тему
Опции темы

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