Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Строки и иже с ними http://www.cyberforum.ru/cpp-beginners/thread127871.html
Как бы странно не звучало, но:я не могу нормально очистить строку в C++ пытаюсь присвоить признак конца строки первому символу строки--он присваивает первому символу, а все остальные так и остаются...
C++ Вывести на экран все различные натуральные числа, символьная запись которых содержится только строго в одной из строк массива Добрый день. Срочно нужна помощь с решением следующей задачи. Помогите кто чем может...)) Дан массив строк. Необходимо вывести на экран все различные натуральные числа, символьная запись которых... http://www.cyberforum.ru/cpp-beginners/thread127867.html
C++ Метод Холецкого для решения Слау
AZigumgaru, Скажу я Вам алгоритм очень прост мне помог вот эти два ресурса (по ним написал программу, использующую алгорит Холецкого)... Ты не мог бы выложить программу?
Перевести натуральное число из десятичной системы в двоичную. C++
Здравствуйте уважаемые форумчане :) Помогите составить программу Перевода числа из десятичной системы в двоичную. Очень блгодарен!!:)
C++ Решить пример http://www.cyberforum.ru/cpp-beginners/thread127843.html
Как вычислить 5 (1+0.04) в степени (1/3) с точностью до 0,001.???
C++ Учу линейные списки, программа не работает... Задача: Ввести Имя и сумму пожертвования. Вывести на печать в порядке убывания по сумме пожертвования. Программа компелируется, но логика подкочала Пример: ------------------------- Дано... подробнее

Показать сообщение отдельно
Genius Ignat
1237 / 775 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
11.05.2010, 23:14
Вот старался, сделал класс матрицы, может кому пригодиться..
Надеюсь ошибок нет.

Класс матрицы
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;
}


++ для среднего арифметического это глупость.
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru