Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Spiderman5
33 / 33 / 30
Регистрация: 07.04.2014
Сообщений: 219
1

Дореализовать класс Вектор

10.06.2014, 15:12. Просмотров 303. Ответов 2
Метки нет (Все метки)

Добрый день ! У меня есть класс Вектор, в котором вектор является одномерным динамическим массивом
и есть класс Матрица, в которой матрица считается массивом векторов.

Матрица у меня более-менее реализована.
Помогите, пожалуйста, для класса Вектор написать несколько методов и перегрузок операций: добавление элемента, удаление элемента, операция +=.
Если что-то ещё важное в класс Вектор можно реализовать - приведите, пожалуйста пример.

Vector.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#pragma once
 
class Vector
{
private:
    int size;
    int capacity;
    int *vector;
public:
    Vector(int size = 1);
    Vector(const Vector& other);
    ~Vector();
 
    // перегрузка операций
    int& operator[](int j); // индексация
    Vector& operator=(const Vector& other);
};
Vector.cpp
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
#include "Vector.h"
 
Vector::Vector(int size)
{
    if (size <= 0)
        size = 1;
    this->size = size;
 
    capacity = size * 2;
    vector = new int[capacity];
    for (int i = 0; i < size; i++)
        vector[i] = 0;
}
 
Vector::Vector(const Vector& other)
{
    size = other.size;
    capacity = other.capacity;
    vector = new int[capacity];
    for (int i = 0; i < size; i++)
        vector[i] = other.vector[i];
}
 
Vector::~Vector()
{
    delete[] vector;
}
 
int& Vector::operator[](int j) // перегрузка операции индексации
{
    if (j < 0)
        j = 0;
    else if (j >= size)
        j = size - 1;
 
    return vector[j];
}
 
Vector& Vector::operator=(const Vector& other) // перегрузка операции присваивания
{
    if (this == &other) // проверка на самоприсваивание
        return *this;
    delete[] vector;
 
    size = other.size;
    capacity = other.capacity;
    vector = new int[capacity];
    for (int i = 0; i < size; i++)
        vector[i] = other.vector[i];
}
Matrix.h
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
#pragma once
#include "Vector.h"
 
class Matrix
{
private:
    int m; // строки
    int n; // столбцы
    int capacity;
    Vector* matrix;
public:
    Matrix(int m = 1, int n = 1);
    Matrix(const Matrix& other);
    ~Matrix();
 
    int Get_Rows() const { return m; }; // строки
    int Get_Columns() const { return n; }; // столбцы
 
    void Set_Data(const int* data); // матрице передаётся массив
 
    // перегрузка операций
    Vector& operator[](int i); // возвращает вектор
    Matrix& operator=(Matrix& other);
    Matrix operator+(Matrix& other);
    Matrix operator*(int multiplier);
    Matrix operator-(Matrix& other);
    Matrix operator~(); // транспонирование
    Matrix operator*(Matrix& other);
};
Matrix.cpp
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
#include "Matrix.h"
 
Matrix::Matrix(int m, int n)
{
    if (m <= 0)
        m = 1;
    /*if (n <= 0)
        n = 1;*/
 
    this->m = m;
    this->n = n;
 
    capacity = m * 2;
    matrix = new Vector[capacity];
    Vector tmp(n);
    for (int i = 0; i < m; i++)
        matrix[i] = tmp;
}
 
Matrix::Matrix(const Matrix& other)
{
    m = other.m;
    n = other.n;
 
    capacity = other.capacity;
    matrix = new Vector[capacity];
    for (int i = 0; i < m; i++)
        matrix[i] = other.matrix[i];
}
 
 
Matrix::~Matrix()
{
    delete[] matrix;
}
 
Vector& Matrix::operator[](int i) // возвращает вектор
{
    if (i < 0)
        i = 0;
    else if (i >= m)
        i = m - 1;
    return matrix[i];
}
 
void Matrix::Set_Data(const int* data)
{
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
        {
            (*this)[i][j] = data[i * n + j]; 
        }
    }
}
 
Matrix& Matrix::operator=(Matrix& other)
{
    if (&other == this) // проверка на самоприсваивание
        return *this;
 
    delete[] matrix;
 
    m = other.m;
    n = other.n;
    capacity = other.capacity;
 
    matrix = new Vector[capacity];
    for (int i = 0; i < m; i++)
        matrix[i] = other.matrix[i];
 
    return *this;
}
 
Matrix Matrix::operator+(Matrix& other) // перегрузка операции сложения матриц
{
    Matrix temp;
    if (m != other.m || n != other.n)
        return temp;
 
    temp = Matrix(m, n);
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
            temp[i][j] = (*this)[i][j] + other[i][j];
    }
 
    return temp;
}
 
Matrix Matrix::operator*(int multiplier) // перегрузка операции умножения матрицы на множитель
{
    Matrix temp(*this);
    for (int i = 0; i < m; i++)
        for (int j = 0; j < n; j++)
            temp[i][j] *= multiplier;
 
    return temp;
}
 
Matrix Matrix::operator-(Matrix& other) // перегрузка операции вычитания матриц
{
    Matrix temp;
    if (m != other.m || n != other.n)
        return temp;
 
    temp = Matrix(m, n);
 
    return (*this) + temp * (-1);
 
    // return (*this) + other * (-1);
}
 
Matrix Matrix::operator*(Matrix& other) // перегрузка операции умножения матриц
{
    Matrix temp;
    if (n != other.m)
        return temp;
 
    temp = Matrix(m, other.n);
 
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < other.n; j++)
        {
            int sum = 0;
 
            for (int k = 0; k < other.n; k++)
            {
                sum += (*this)[i][k] * other[k][j];
            }
 
            temp[i][j] = sum;
        }
    }
    return temp;
}
 
Matrix Matrix::operator~() // перегрузка операции транспонирования
{
    /*Matrix temp(n, m);
 
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
        {
            temp[j][i] = (*this)[i][j];
        }
    }
 
    return temp;*/
 
    Matrix temp(m, n);
 
    for (int i = 0; i < m; i++)
    {
        for (int j = 0; j < n; j++)
        {
            temp[j][i] = (*this)[i][j];
        }
    }
 
    return temp;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.06.2014, 15:12
Ответы с готовыми решениями:

Класс "вектор" с конструкторами, позволяющими создать нулевой вектор и вектор с произвольным числом элементов
Привет! Задача следующая. Нужно реализовать класс &quot;вектор&quot; с...

Нужно дореализовать доступ по индексу в матрице
В общем, не могу доделать доступ по индексу - не знаю, как избавиться от...

Создать класс, полем которого является класс вектор
как это выглядит?

Класс вектор
необходимо написать класс вектор (в геометрическом смысле в трёхмерном...

Класс вектор
У меня есть задача: Разработать пользовательский тип “ вектор в n-мерном...

2
Тамика
Котовчанин
919 / 463 / 195
Регистрация: 16.02.2010
Сообщений: 3,267
Записей в блоге: 32
10.06.2014, 16:02 2
У меня в блогах есть класс int_array. Сделан по тому же мотиву. Можете взглянуть. Что-то добавить себе.
1
Spiderman5
33 / 33 / 30
Регистрация: 07.04.2014
Сообщений: 219
10.06.2014, 17:03  [ТС] 3
Спасибо, посмотрю
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.06.2014, 17:03

Класс Вектор
Помогите пожалуйста горит индевидуалка... Создать класс векторов...

Класс вектор
Помогите сделать

Вектор класс
Всем привет!!! Вот написал программу с класами а она не правильно работеает....


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

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