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

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

Восстановить пароль Регистрация
 
Spiderman5
31 / 31 / 14
Регистрация: 07.04.2014
Сообщений: 215
10.06.2014, 15:12     Дореализовать класс Вектор #1
Добрый день ! У меня есть класс Вектор, в котором вектор является одномерным динамическим массивом
и есть класс Матрица, в которой матрица считается массивом векторов.

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

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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.06.2014, 15:12     Дореализовать класс Вектор
Посмотрите здесь:

Класс Вектор C++
Класс вектор C++
Класс вектор C++
C++ Класс-вектор в С++
Нужно дореализовать доступ по индексу в матрице C++
C++ Класс вектор С++
C++ класс Вектор
C++ Нужно реализовать класс "вектор" с конструкторами, которые позволяют создать нулевой вектор и вектор с произвольным кол-во элементов.

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Тамика
Котовчанин
 Аватар для Тамика
859 / 439 / 129
Регистрация: 16.02.2010
Сообщений: 2,543
Записей в блоге: 27
10.06.2014, 16:02     Дореализовать класс Вектор #2
У меня в блогах есть класс int_array. Сделан по тому же мотиву. Можете взглянуть. Что-то добавить себе.
Spiderman5
31 / 31 / 14
Регистрация: 07.04.2014
Сообщений: 215
10.06.2014, 17:03  [ТС]     Дореализовать класс Вектор #3
Спасибо, посмотрю
Yandex
Объявления
10.06.2014, 17:03     Дореализовать класс Вектор
Ответ Создать тему
Опции темы

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