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

Классы: перегрузка операторов - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ время дата http://www.cyberforum.ru/cpp-beginners/thread997574.html
время дата создания файла в с++ как?
C++ Массивы! Подправьте прогу! Подскажите ошибки! Прога должна: 1. Превращать в массив введенную строку символов и выводить массив на экран. 2. Из массива сгенерированых чисел найти разность между суммами четных и нечетных элементов и вывести на экран. 3. Сделать циклическое смещение алгоритма влево заданное количество раз! 2 часть работает, 1 не работает, а 3 работает через раз(раз выводит правильное количество... http://www.cyberforum.ru/cpp-beginners/thread997562.html
C++ Открыть файл, имя которого задается с клавиатуры. Посчитать количество байт в этом файле. Первую половину прочитанного файла записать в другой файл.
ребят помогите! плиз!!1. Открыть файл, имя которого задается с клавиатуры. Посчитать и вывести на эк-ран количество байт в этом файле. Первую половину прочитанного файла записать в другой файл. Вывести полученный файл на экран.
C++ Проверка индекса массива на степень тройки
#include <iostream> #include <locale> using namespace std; bool Pow3(int k) { //Проверка индекса на степень тройки. int m=1; while(m<=k) { if(k==m) return true; m*=3;
C++ Машинно-зависимая оптимизация http://www.cyberforum.ru/cpp-beginners/thread997539.html
Собственно, требуется оптимизировать некоторый код на с++ с помощью м-з оптимизации. Какие есть несложные способы это реализовать?
C++ метод Фостера 1. методом Фостера-Стюарта проверить гипотезу о существовании тенденции в социально-экономическом процессе( индивидуальные задания напишу ниже). 2. В случае обнаружения тенденции в средней подобрать для нее форму кривой, т.е. методом последовательных разностей определить степень аппроксимирующего полинома. 3. Непосредственным методом наименьших квадратов найти коэффициенты аппроксимирующего... подробнее

Показать сообщение отдельно
Rashaveran
0 / 0 / 0
Регистрация: 30.10.2013
Сообщений: 2

Классы: перегрузка операторов - C++

04.11.2013, 16:13. Просмотров 449. Ответов 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
#include "stdafx.h"
#include <iostream>
#include <locale>
using namespace std;
 class Matrix
{
    private:
        long int **Matr;
        
     public:
        long int m;
        long int n;
 
        Matrix(long int i, long int j): m(i), n(j)
        { 
            Matr = new long int*[m];
            for (int z=0; z<m; z++)
                Matr[z] = new long int[n]; 
            for (int i=0; i<n; i++)
                {
                    for (int j=0; j<m; j++)
                    Matr[i][j] = rand()%100+1;
                 }
        }
        ~Matrix()
        {
            for (int z=0; z<m; z++)
                delete[] Matr[z];
            delete[] Matr;
        }
       void Display()
        {
            for(int i=0; i<m; i++)
            {
                for(int j=0; j<n; j++)
                {
                    cout.width(4);
                    cout << Matr[i][j];
                }
                cout << endl;
            }
        }
       Matrix operator+ (const Matrix my)
        { 
            Matrix m_ret(m, n);
            for(int i=0; i<m; i++)
            {
                for(int j=0; j<n; j++)
                {if(i==j)
                {m_ret.Matr[i][j]=Matr[i][j]+my.Matr[i][j];}
                else m_ret.Matr[i][j]=0;
                }
                
            }
            return m_ret;
       }
       Matrix operator=(const Matrix my)
        {
            Matrix m_ret(m, n);
            for(int i=0; i<m; i++)
            {
                for(int j=0; j<n; j++)
                {m_ret.Matr[i][j]=my.Matr[i][j];
                }
            }
            return m_ret;
        }
       Matrix operator++()
       {Matrix m_ret(3, 3);
       for(int i=0; i<3; i++)
            {
                for(int j=0; j<3; j++)
                {Matr[i][j]++;
                }
       }
       return *this;
       }
        };
 
int main()
{   setlocale( LC_ALL,"Russian" );
    int u;
    cout<<"Введите размер матриц"<<endl;
    cin>>u;
    Matrix M(u,u);
    M.Display();
    cout<<endl;
    Matrix N(u,u);
    N.Display();
    cout<<"Матрица ++"<<endl;
    ++N;
    N.Display();
    Matrix K(u,u);
    cout<<"Сумма матриц"<<endl;
    K=M+N;
    K.Display();
    return 0;
}
Матрицу создает, но затем программа грохается. Помогите, как нужно правильно написать перегрузку, а то уже задолбался.

Буду ОЧЕНЬ благодарен
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru