Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
1 / 1 / 1
Регистрация: 28.10.2010
Сообщений: 112

Очень непростая программа с класами!

16.05.2011, 16:22. Показов 793. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!
Нужно сделать класс Matrix (квадратная матрица)
Действия: -=, *=.
Класс должен иметь конструкторы, для создания объектов некоторого типа( конструктор за умолчанием и из параметрами, конструктор копирования). Обезательно нужно использовать перегрузку операторов!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.05.2011, 16:22
Ответы с готовыми решениями:

Не корректно работает программа с класами
Привет Всем. У меня есть к Вам просьба. Я вот написал программу,но в ней редактирование и удаление данных из базы данных работает не...

Очень непростая задача. Поворот кнопки мышкой вокруг оси
Задача: Нужно осуществить вращение кнопки, путем SetBounds При нажатии на правый край кнопки, в MouseMove ее нужно...

Программа ест очень-очень много ОЗУ
При запуске - 14-16 МБ! А весь "прикол" в том... что на в ней ничего нет! Лишь одна форма - и все! Добавляю пару picturebox ов - уже 25 МБ....

8
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
16.05.2011, 18:35
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
#include <iostream>
 
class Matrix
{
public:
    Matrix(size_t size = 2):
    m_matrix(new double *[size]),
    m_size(size)
    {
        for (size_t i = 0; i < m_size; ++i)
        {
            m_matrix[i] = new double [m_size];
 
            for (size_t j = 0; j < m_size; ++j)
                m_matrix[i][j] = 0;
        }
    }
 
    Matrix(const Matrix &source):
    m_matrix(new double *[source.m_size]),
    m_size(source.m_size)
    {
        for (size_t i = 0; i < m_size; ++i)
        {
            m_matrix[i] = new double [m_size];
 
            for (size_t j = 0; j < m_size; ++j)
                m_matrix[i][j] = source.m_matrix[i][j];
        }
    }
 
    ~Matrix()
    {
        for (size_t i = 0; i < m_size; ++i)
            delete [] m_matrix[i];
 
        delete [] m_matrix;
    }
 
    void input()
    {
        for (size_t i = 0; i < m_size; ++i)
        {
            for (size_t j = 0; j < m_size; ++j)
            {
                std::cout << "matrix[" << i << "][" << j << "] = ";
                std::cin >> m_matrix[i][j];
            }
        }
    }
 
    void print() const
    {
        for (size_t i = 0; i < m_size; ++i)
        {
            for (size_t j = 0; j < m_size; ++j)
                std::cout << m_matrix[i][j] << "  ";
 
            std::cout << std::endl;
        }
    }
 
    Matrix &operator-=(const Matrix &right)
    {
        if (m_size == right.m_size)
            for (size_t i = 0; i < m_size; ++i)
                for (size_t j = 0; j < m_size; ++j)
                    m_matrix[i][j] -= right.m_matrix[i][j];
 
        return *this;
    }
 
    Matrix &operator*=(const Matrix &right)
    {
        Matrix result(m_size);
 
        if (m_size == right.m_size)
        {
            for (size_t i = 0; i < m_size; ++i)
                for (size_t j = 0; j < m_size; ++j)
                    for (size_t k = 0; k < m_size; ++k)
                        result.m_matrix[i][j] += m_matrix[i][k] * right.m_matrix[k][j];
 
            *this = result;
        }
 
        return *this;
    }
 
    Matrix &operator=(const Matrix &source)
    {
        if (this != &source)
        {
            if (m_size != source.m_size)
            {
                for (size_t i = 0; i < m_size; ++i)
                    delete [] m_matrix[i];
 
                delete [] m_matrix;
 
                m_size = source.m_size;
 
                m_matrix = new double *[m_size];
 
                for (size_t i = 0; i < m_size; ++i)
                    m_matrix[i] = new double [m_size];
            }
 
            for (size_t i = 0; i < m_size; ++i)
                for (size_t j = 0; j < m_size; ++j)
                    m_matrix[i][j] = source.m_matrix[i][j];
        }
 
        return *this;
    }
 
private:
    double **m_matrix;
    size_t m_size;
};
 
int main()
{
    Matrix m1(2), m2(2);
    
    m1.input();
    m2.input();
 
    Matrix m3 = m1, m4 = m1;
 
    m3 -= m2;
    m4 *= m2;
 
    m3.print();
    m4.print();
 
    return 0;
}
1
1 / 1 / 1
Регистрация: 28.10.2010
Сообщений: 112
16.05.2011, 19:55  [ТС]
Большое вам спасибо, вы мне очень помогли, программа работает отлично!

Добавлено через 57 минут
Ещё один вопрос, как можно шагам расписать этот оператор *=.
Я просто немогу понять принцип его работы, если например а=5, b=4, то почему результат 24, где логика)
Зарание спасибо!
0
 Аватар для m1Rr0r
250 / 232 / 46
Регистрация: 05.02.2010
Сообщений: 3,288
16.05.2011, 20:29
Цитата Сообщение от AndreyZ01 Посмотреть сообщение
Ещё один вопрос, как можно шагам расписать этот оператор *=
предположу....
береться левая матрица умножаеться на правую и результат заноситься в левую
A = A * B
A*=B
Две записи идентичны
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
16.05.2011, 20:37
Логика здесь.

Добавлено через 1 минуту
Цитата Сообщение от 'm1Rr0r' Посмотреть сообщение
Две записи идентичны
С той только разницей, что первая запись не сработает, поскольку оператор * не перегружен.
Однако, полагаю, вопрос был не об этом.
0
1 / 1 / 1
Регистрация: 28.10.2010
Сообщений: 112
16.05.2011, 20:50  [ТС]
Всё равно непонимаю, если первая матрица равно 10, вторая 3 то что будет результатом?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
16.05.2011, 20:56
Вы понимаете, что такое матрицы?
0
1 / 1 / 1
Регистрация: 28.10.2010
Сообщений: 112
16.05.2011, 21:06  [ТС]
Да, понимаю.

Добавлено через 1 минуту
Всё, разобрался, я думал что програма обрабатывает каждый элемент по отдельности, а она просто перемноживает матрицы.
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
16.05.2011, 21:12
Не совсем понятно, что вы ожидали увидеть... Обычно операция перемножения матриц "просто перемноживает матрицы".
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.05.2011, 21:12
Помогаю со студенческими работами здесь

Ошибка с класами
Нашел себе книгу &quot;С++ за 21 день&quot; и там начал делать примеры. Но почему-то дойдя до классов ничего получается. Rect.h #include...

Работа с Класами в С++
Люди виручайте есть такое задание: Написати клас для ефективної роботи з рядками, дозволяючий форматувати і порівнювати рядки,...

Проблема с класами
Вот пытаюсь описать клас(умова задачи в коментариях)но когда запускаю выбивает какуюту ошыбку типа необратимое исключения типов и тд...

Робота с класами
Я пишу програму на задачу: Дано формулу ? 1 ? 2 ? … ? n = k. вместо ? должны стоять знаки + или - мы вводим число k а нам должно...

Легкое задание с класами
Помогите решить задание... Пропустил несколько занятий и сейчас немного не понимаю, так хоть по готовому примеру разберусь ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru