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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Структуры и ввод строк с пробелами: программа пропускает второй шаг, сразу переходя к третьему - почему? http://www.cyberforum.ru/cpp-beginners/thread1204557.html
Здравствуйте, уважаемые форумчане! Я новичок и в С++ и на этом форуме, так что прошу сильно не пинать. Начал заниматься по книге Стивена Праты "Язык программирования С++" (Лекции и упражнения, 2011). Операционная система на компе у меня Windows XP SP3 (+все обновления), среда разработки Code::Blocks (версия 13.12). Делаю практические задания (упражнения по программированию) из 4 главы. Сделал...
C++ Параллельное программирование Скажиет, пожалуйста, могут ли общаться процессы, принадлежащие разным коммуникаторам? (OpenMPI) http://www.cyberforum.ru/cpp-beginners/thread1204550.html
Snake в консоле C++
Решил попробовать написать игру в консоле, остановился на легендарной Snake. Опции (в виде увеличения, препятствия, и т.д.) еще не делал, решил для начала запустить, посмотреть будет ли работать. Ну и вообщем первые 2 хода на вид нормально, а дальше что попало начинается. Вроде передвигается во всех 4х направлениях, но отображается не корректно. Для того что бы было видно в чем проблема, я...
Записать в выходной файл частоты появлений всех двухбуквенных сочетаний, имеющихся в тексте C++
3. Дан текст на русском языке. Записать в выходной файл частоты появлений всех двухбуквенных сочетаний, имеющихся в тексте.
C++ Ошибки в примере:"newline in constant"и"unexpected end of file while looking for precompiled header directive" http://www.cyberforum.ru/cpp-beginners/thread1204502.html
здравствуйте. учусь по книге Шилдта там такой пример( да и везде впринципе начинают с этого примера) #include "iostream> using namespace std; int main() { cout <<"C++ - ýòî ñèëà"; return 0; }
C++ Считать предложения из файла и записать их в другой файл по количеству слов в предложении здравствуйте) помогите пожалуйста, срочно надо!!) написать программу, которая считывает предложения из файла и записывает в другой файл их по количеству слов в предложении подробнее

Показать сообщение отдельно
Spiderman5
31 / 31 / 14
Регистрация: 07.04.2014
Сообщений: 219

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

10.06.2014, 15:12. Просмотров 242. Ответов 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru