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

Как сделать так чтобы при каждом выделении памяти в методе была возможность ее очистить и вернуть результат? - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Динамический ввод строки http://www.cyberforum.ru/cpp-beginners/thread1165706.html
замените ввод на динамический #include <stdio.h> #include <conio.h> #include <iostream> #define sn 100 // максимальное количество строк #define len 200 // максимальная длина одной строки int main() {
C++ Статический массив неопределенного размера Добрый день! Помогите, пожалуйста, разобраться вот с этим кодом: #include <iostream> using namespace std; main () { int x; cin >> x; int array ; }Почему этот код компилируется и выполняется? Разве при объявлении размер массива не должен быть задан константой? Это что, какой-то новый стандарт? (компилятор g++) Заранее спасибо! http://www.cyberforum.ru/cpp-beginners/thread1165703.html
С++ логические выражения и классы C++
Помогите пожалуйста запрограммировать блок выбора режима. Нужно сделать через классы.С++
Генерация случайного четырехзначного числа без цифр, больших 7 и 0 C++
Нужно сгенерировать случайное четырехзначные число без цифр, больших 7 и 0. Пишу вот такой код: Но он ничего не выводится. Зацикливается. Но, когда убираю условие про 0 (в 19 строке), то выводит 3 числа, всегда одинаковых. Как-будто дальше число с цифрой, больше 7, и опять зацикливается. Возникают вопросы: 1) Почему зацикливается? 2) Как сделать, чтобы числа всегда были разные? #include...
C++ Как вывести на екран структуру/класс через vector или list http://www.cyberforum.ru/cpp-beginners/thread1165644.html
Всем привет.Подскажите как через итераторы правильно вывести структуру или класс в поток. Как я понял для стандартных типов они выводятся следующим образом: list<int> t; for(int i(0);i<20;i+=2) t.push_back(i); list<int>::const_iterator it; for(it = t.begin();it != t.end();it++) cout<<*it<<"\t"; и впринципи все нормально выводится(с вектором все точно также). Но...
C++ Переставить числа в последовательности , что бы сначала шли числа равные первому члену, затем равные второму и тд Помогите пожалуйста! Не могу решить задачу на перемещение элементов массива Даны целые числа a1,....,an. Переставить числа в последовательности таким образом, что бы сначала шли все числа, равные первому члену, затем - равные второму и тд. Мой код не работает #include <iostream> #include <clocale> using namespace std; int main() подробнее

Показать сообщение отдельно
MatthewThunder
0 / 0 / 0
Регистрация: 15.05.2013
Сообщений: 18
04.05.2014, 12:26     Как сделать так чтобы при каждом выделении памяти в методе была возможность ее очистить и вернуть результат?
Доброго времени суток! Есть код класса и хотелось бы устранить в нем следующие недочеты:
1) Как сделать так чтобы при каждом выделении памяти в методе была возможность ее очистить и вернуть результат?
2) Как при таком типе данных vector <vector<int>> реализовать функцию добавления элемента? (что-то типа push_back() )
Заранее спасибо!
push_back() который сейчас не работает.
Вот код:

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
165
166
167
168
169
170
171
172
173
#pragma once
#include <vector>
#include <string>
#include <iostream>
using std::vector;
using std::cout;
using std::string;
using std::istream;
using std::ostream;
class _matrix
{
private:
    vector <vector<int>> data;
    int row;
    int col;
    string operat;
public:
    _matrix() {};
    _matrix(int rows, int cols,string operation)
    {
        row = rows;
        col = cols;
        operat = operation;
        data.resize(row, vector<int>(col));
    }
    _matrix(const _matrix &obj)
    {
        row = obj.row;
        col = obj.col;
        operat = obj.operat;
        data = obj.data;
    }
    ~_matrix()
    {
        data.clear();
    }
    //Сложение двух матриц
    _matrix& operator+(_matrix &obj2)
    {
        _matrix* obj = new _matrix(*this);
        for (int i = 0; i < obj2.row; i++)
        for (int j = 0; j < obj2.col; j++)
            (*obj)(i, j) = (*this)(i, j) + obj2(i, j);
        return *obj;
    }
    //вычитание двух матриц
    _matrix& operator-(_matrix &obj2)
    {
        _matrix* obj = new _matrix(*this);
        for (int i = 0; i < obj2.row; i++)
        for (int j = 0; j < obj2.col; j++)
            (*obj)(i, j) = (*this)(i, j) - obj2(i, j);
        return *obj;
    }
    //Умножение двух матриц
    _matrix &operator*(_matrix &obj2)
    {
        _matrix* obj = new _matrix(*this);
        for (int i = 0; i < obj->row; i++)
        for (int j = 0; j < obj2.col; j++)
        {
            (*obj)(i, j) = obj2(i, j) * (*this)(i, j);  
        }
        return *obj;
    }
    //Умножение матрицы на число
    _matrix &operator*(int q)
    {
        _matrix* obj = new _matrix(*this);
        for (int i = 0; i < obj->row; i++)
        for (int j = 0; j < obj->col; j++)
        {
                (*obj)(i, j) *= q;
        }
        return *obj;
    }
    //Возведение матрицы в степень
    _matrix &operator^(int q)
    {
        _matrix* obj = new _matrix(*this);
        for (int i = 0; i < obj->row; i++)
        for (int j = 0; j < obj->col; j++)
        {
            for (int k = 0; k < q; k++)
            {
                (*obj)(i, j) *= (*obj)(i, j);
            }
        }
        return *obj;
    }
    //Приравнивание матриц
    _matrix &operator=(const _matrix &obj)
    {
        row = obj.row;
        col = obj.col;
        data = obj.data;
        return *this;
    }
    //Транспонирование
    _matrix &transpon()
    {
        _matrix transobj(*this);
        for (int i = 0; i < (*this).row - 1; i++)
        for (int j = 0; j < (*this).col - 1; j++)
            (*this)(i, j) = transobj(j, i);
        return *this;
    }
    void add_element(int e)
    {
        (*this).data.push_back(e);
    }
    //Возвращает тип операции
    string operation_type()
    {
        return (*this).operat;
    }
    //Возвращает значение элемента матрицы
    int &operator()(int& i, int& j)
    {
        return (*this).data[i][j];
    }
    //Возвращает количество столбцов
    int get_cols()
    {
        return (*this).col;
    }
    //Возвращает количество строк
    int get_rows()
    {
        return (*this).row;
    }
    //"Дружелюбные методы"
    friend ostream &operator<<(ostream &stream, _matrix &obj);
    friend istream &operator>>(istream &stream, _matrix &obj);
};
//Перегружаем оператор сдвига чтобы он сразу формировал JSON-строку
ostream &operator<<(ostream &stream, _matrix &obj)
{
    stream << "{";
    stream << "\"rows\":" << obj.row << ", \"cols\": " << obj.col;
    stream << ", \"data\" : [";
    for (int i = 0; i < obj.row; i++)
    {
        for (int j = 0; j < obj.col; j++)
        {
            if (j + 1 == obj.col)
            {
                stream << obj(i, j);
            }
            else
            {
                stream << obj(i, j) << ",";
            }
        }
        if (i + 1 == obj.col)
        {
            stream << "]";
        }
        else
        {
            stream << ",";
        }
    }
    stream << "}";
    return stream;
}
istream &operator>>(istream &stream, _matrix &obj)
{
    for (int i = 0; i < obj.row; i++)
    for (int j = 0; j < obj.col; j++)
        stream >> obj(i, j);
    return stream;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru