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

Помогите отладить программу: Разработать класс, содержащий вектор длинных целых чисел

12.05.2015, 20:12. Показов 2037. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Нужна ваша помощь. Ниже задания что бы вы были в курсе что я делаю. Примерно половину заданий я уже выполнил, однако есть кое какие вопросы.
1) конструктор копирования..я не уверен что я его правильно создал и "вызвал"
2) как правильно реализовать деструктор для моего варианта. Если откоментировать то что я написал то при вызове функций или методов сортировки и вывода на экран возникает ошибка
3) пожалуй самое важное, в чем пока не разберусь где что не так - это "установление новых значений в объекте после сортировки". Сама сортировка работает. Всё сортируется и даже передаётся в класс, но обновить вектор так и не получается.

Проверить конструкторы/деструкторы и помогите найти ошибку с сортировкой. Пока не разберусь с этим и не станет всё как надо работать 2-е задание с перегрузкой делать пока не имеет большого смысла. Также буду благодарен если кто-нить поможет и с перегрузкой, хотя бы с "подходящей под мой случай" теорией, так как сам только поверхностно знаю как это реализовать.


Класс должен включать:
- компоненты данные
- методы:
а) конструктор по умолчанию;
б) конструктор с параметрами;
в) конструктор копирования;
г) деструктор;
д) методы класса для работы с данными.
Компоненты данные класса должны иметь атрибут private или protected (в зависимости от необходимости).
При реализации задания 1 функцию вывода содержимого объекта реализовать как внешнюю по отношению к классу
При реализации задания 3 в базовый класс (кроме перечисленных выше) добавить методы: set – инициализации данных базового класса, get – возврата данных класса.

Задания:
1. Разработать класс А, одной из компонент которого является вектор длинных целых чисел и внешнюю функцию (по отношению к классу А), выполняющую упорядочивание чисел в векторе (по возрастанию). Содержимое объекта (вектор чисел) до и после применения к нему внешней функции вывести на экран.
2. Создать несколько объектов (например, a и b) разработанного класса. Класс – вектор (одномерный массив). Реализовать для объектов данного класса перегрузку операции < ( a<b; ) при этом в объект а заносится меньшее а в объект b большее из 2 чисел массивов в сравниваемых объектах.
3. Создать иерархию классов представляющих простое наследование. Базовый класс – вектор (числовой динамический массив (int *)). Производный класс – методы, работающие с данными базового класса. Реализовать в производном классе метод – нахождения в векторе элементов с нечетными значениями и удаления их вектора.


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
//---------------------------------------------------------------------------
#include <vcl.h>
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <conio.h>
#include <vector>
#pragma hdrstop
#include <stdio.h>
#include <string.h>
 
using namespace std;
 
class A{
   private:
      vector <int> numbers;
      int size;
 
   public:
      // конструктор по умолчанию
      A(){
         int rnd;
         srand(time(0));
         for (int i=0; i<20; i++){
            rnd = rand() % 100;
            (this->numbers).push_back(rnd);
         }
         this->size=20;
      }
 
      // конструктор с параметрами
      A(int count){
         int rnd;
         srand(time(0));
         for (int i=0; i<count; i++){
            rnd = rand() % 100;
            (this->numbers).push_back(rnd);
         }
         this->size = count;
      }
 
      // конструктор копирования   ???
      A(const A & source){
         int rnd;
         srand(time(0));
         for (int i=0; i<10; i++){
            rnd = rand() % 100;
            numbers = source.numbers;
            (this->numbers).push_back(rnd);
        }
        this->size = 10;
      }
 
   // деструктор    ???
   ~A(){
       // delete []&numbers; // происходит ли удаление при помощи данной строки?
       // numbers.clear();
   }
 
      //get-метод для 3-го задания (получение значений вектора)
      vector <int> get(){
        return this->numbers;
      }
 
      //set-метод для 3-го задания  (установить рандомные значения)
      void set(int count){
         int rnd;
         srand(time(0));
         for (int i=0; i<count; i++){
            rnd = rand() % 100;
            (this->numbers).push_back(rnd);
         }
      }
 
      // установить отсортированный test-массив
      void setSorting(vector <int> test){
          for (int i=0; i<test.size(); i++){
                this->numbers[i]=test[i];
                cout<< test[i]<<" ";
          }
      }
 
      //просто метод для вывода содержимого на экран
      void printValue(){
         for(int i=0; i<(this->numbers).size(); i++)
         cout<< this->numbers[i]<<" ";
      }
} ;
 
//-------------------------------------------------------------------------------
// функция для для сортировки для 1-го задания (отсортированный масссив хранится в test)
void sort(A obj){
   int temp;
   vector <int> test;
   test = obj.get2();
   test.pop_back() ;
   for (int i=0; i<test.size(); i++){
      for (int j=0; j<i; j++){
         if (test[j]>test[j+1]) {
            temp = test[j];
            test[j] = test[j+1] ;
            test[j+1] = temp;
            i--;
         }
      }
   }
   obj.setSorting(test);
}
 
   // функция для вывода на экран для 1-го задания (аналогична методу printValue())
   void Print(A obj){
        cout<<endl;
   vector <int> test;
        test = obj.get2();
         for(int i=0; i<test.size()-1; i++){
        cout<<test[i]<<endl;
          }
   }
 
#pragma argsused
int main(int argc, char* argv[])
{
   setlocale(LC_ALL, "rus");
 
   A vectors1;   // вызов конструктора по умолчанию
   A vectors2(10);// вызов конструктора с параметрами
   A vectors3 = vectors1; //вызов копирующего конструктора   ??
 
   
   cout<<"Do sortirovki"<<endl;
   vectors1.printValue();
   cout<<endl<<endl;
 
   cout<<"SORTIROVKA"<<endl;
   sort(vectors1);
   cout<<endl<<endl;
 
   cout<<"Posle sortirovki"<<endl;
   vectors1.printValue();
   cout<<endl<<endl;
 
   getch();
   return 0;
}
//---------------------------------------------------------------------------
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.05.2015, 20:12
Ответы с готовыми решениями:

Создать класс длинных целых чисел
Создать класс длинных целых чисел. Класс имеет конструктор по умолчанию, конструктор - преобразующий long в объект класса. Определить...

Помогите пожалуйста по Одномерному массиву длинных целых чисел!!!
Здравствуйте!!! Помогите пожалуйста решение задачи!!! Одномерный массив длинных целых чисел Задание №1 Составить программу...

Создать класс СПИСОК целых чисел. Разработать класс СТЕК
&quot;Создать класс СПИСОК целых чисел. Разработать класс СТЕК, который вмещает объект класса СПИСОК. Определить необходимые конструкторы,...

1
2 / 2 / 4
Регистрация: 08.09.2013
Сообщений: 94
19.05.2015, 21:12  [ТС]
прошло уже около недели а никто так и не ответил(
надеюсь хоть сейчас поможете
сделал все задания..всё компилируется..всё работает...есть некоторые недочеты, хочу спросить как от них избавиться

в 1) задании как и было..не уверен в конструкторе копирования и конструкторе...функция сортировки и вывода вроде работает..может и в ней найдете что-то не так

во 2) сделал перегрузку.работает, но после перезагрузки у 2-го объекта появляются в конце 2 элемента, которые я пока не знаю как удалить или скрыть.
пробовал при помощи. Одно число удаляет, а вот при удалении 2-го последний нужный элемент в одном из объектов меняется на "новый"
C++
1
a.numbers.erase(a.numbers.end()-1);
3) тоже сделал через указатели..реализовала гетторы и сетторы, а вот само удаление не получается, хотя нахождение нужных элементов правильное, возможно из-за того что не срабатывает 2-ая строчка
C++
1
2
a.erase(a.begin() + i); 
//vector<int>(a).swap(a);
надеюсь кто-нить откликнутся

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
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
//---------------------------------------------------------------------------
#include <vcl.h>
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <conio.h>
#include <vector>
#pragma hdrstop
#include <stdio.h>
#include <string.h>
 
 
using namespace std;
 
class A{
   private:
      vector <int> numbers;
      int size;
 
   public:
      // êîíñòðóêòîð ïî óìîë÷àíèþ
      A(){
         int rnd;
         srand(time(0));
         for (int i=0; i<20; i++){
            rnd = rand() % 100;
            (this->numbers).push_back(rnd);
         }
         this->size=20;
      }
 
      // êîíñòðóêòîð ñ ïàðàìåòðàìè
      A(int count){
         int rnd;
         //srand(time(0));
         for (int i=0; i<count; i++){
            rnd = rand() % 100;
            (this->numbers).push_back(rnd);
         }
         this->size = count;
      }
 
      // êîíñòðóêòîð êîïèðîâàíèÿ   ???
      A(const A & source){
         int rnd;
         srand(time(0));
         for (int i=0; i<10; i++){
            rnd = rand() % 100;
            numbers = source.numbers;
            (this->numbers).push_back(rnd);
        }
        this->size = 10;
      }
 
      //äåñòðóêòîð
      ~A(){
        numbers.clear();
      }
 
      //get-ìåòîä äëÿ ïîëó÷åíèå çíà÷åíèé âåêòîðà
      vector <int> get(){
        return this->numbers;
      }
 
      //set-ìåòîä äëÿ óñòàíîâëåíèÿ ðàíäîìíûõ çíà÷åíèé
      void set(int count){
         int rnd;
         srand(time(0));
         for (int i=0; i<count; i++){
            rnd = rand() % 100;
            this->numbers.push_back(rnd);
         }
      }
 
      // óñòàíîâèòü îòñîðòèðîâàííûé test-ìàññèâ
      void setSorting(vector <int> test){
          for (int i=0; i<test.size(); i++){
                this->numbers[i]=test[i];
                cout<< test[i]<<" ";
          }
      }
 
      //ïðîñòî ìåòîä äëÿ âûâîäà ñîäåðæèìîãî íà ýêðàí
      void printValue(){
         for(int i=0; i<(this->numbers).size(); i++)
         cout<< this->numbers[i]<<" ";
      }
 
      // ïåðåãðóçêà îïåðàòîðà >
      A operator >(A a){
        int temp;
        for (int i=0; i<a.numbers.size(); i++){
                if (this->numbers[i]>a.numbers[i]){
                temp = a.numbers[i];
                a.numbers[i]= this->numbers[i];
                this->numbers[i] = temp;
                }
        }
 
        //cout<<endl<<this->numbers.size()<<endl;  //10
        //cout<<endl<<a.numbers.size()<<endl;      //11
        //a.numbers.erase(a.numbers.end()-1);
    return a;
        //return *this;
      }
} ;
 
//çàäàíèå 3
class Vector{
        protected:
           vector <int*> MyVector;
        public:
          vector <int*> get(){
             return this->MyVector;
          }
 
          void set(int count){
             int rnd;
             srand(time(0));
             vector <int> a;
             for (int i=0; i<count+1; i++){
                rnd = rand() % 100;
                a.push_back(rnd);
                this->MyVector.push_back(&a[i]);
                if (i!=0) cout<<a[i]<<" ";
             }
          }
};
 
class VectorProizvodny: public Vector {
       public:
          void print(){
             vector <int*> a;
             a=this->get();
             vector <int> b;
             for (int i=1; i<this->MyVector.size(); i++){
             cout<<*a[i]<<" ";
             }
          }
 
          void clear(){
             vector <int*> a;
             a=this->get();
             for (int i=1; i<a.size(); i++){
                    if (*a[i]%2==0) {
                    //âîò ñäåñü íàõîäèò ïðàâèëüíî, íî óäàëÿåò íå âåðíî
                        cout<<*a[i]<<" ";
                        a.erase(a.begin() + i);
                        //vector<int>(a).swap(a);
                    }
 
 
             }
             cout<<" - nuzhnye elementy"<<endl;
             // âûâîä ïîñëå óäàëåíèÿ (îòëè÷àåòñÿ îò ïðèäûäóùåãî)
             for (int i=1; i<a.size(); i++){
                 cout<<*a[i]<<" ";
              }
              cout<<" - vyvod posle udalenya nvunri methoda"<<endl;
          }
} ;
//-------------------------------------------------------------------------------
// ôóíêöèÿ äëÿ äëÿ ñîðòèðîâêè äëÿ 1-ãî çàäàíèÿ (îòñîðòèðîâàííûé ìàñññèâ õðàíèòñÿ â test)
vector <int> sort(A obj){
   int temp;
   vector <int> test;
   test = obj.get();
   test.pop_back() ;
   for (int i=0; i<test.size(); i++){
      for (int j=0; j<i; j++){
         if (test[j]>test[j+1]) {
            temp = test[j];
            test[j] = test[j+1] ;
            test[j+1] = temp;
            i--;
         }
      }
   }
   return test;
}
 
   // ôóíêöèÿ äëÿ âûâîäà íà ýêðàí äëÿ 1-ãî çàäàíèÿ (àíàëîãè÷íà ìåòîäó printValue())
   void Print(A obj){
        cout<<endl;
        vector <int> test;
        test = obj.get();
        for(int i=0; i<test.size()-1; i++){
           cout<<test[i]<<endl;
        }
   }
 
#pragma argsused
int main(int argc, char* argv[])
{
   setlocale(LC_ALL, "rus");
 
 
   cout<<"ZADANIE 1"<<endl<<endl;
   A vectors1;   // âûçîâ êîíñòðóêòîðà ïî óìîë÷àíèþ
   A vectors2(10);// âûçîâ êîíñòðóêòîðà ñ ïàðàìåòðàìè
   A vectors3 = vectors1; // âûçîâ êîïèðóþùåãî êîíñòðóêòîðà
 
 
   cout<<"Do sortirovki"<<endl;
   vectors1.printValue();
   cout<<endl<<endl;
 
   cout<<"SORTIROVKA"<<endl;
   vectors1.setSorting(sort(vectors1)) ;
   cout<<endl<<endl;
 
   cout<<"Posle sortirovki"<<endl;
   vectors1.printValue();
   cout<<endl<<"______________________________________________"<<endl;
 
   cout<<endl<<endl<<"ZADANIE 2"<<endl<<endl;
   A a(10);
   A b(10);
   cout<<"object 1:  ";
   a.printValue();
   cout<<endl<<endl;
   cout<<"object 2:  ";
   b.printValue();
 
   cout<<endl<<endl<<"Peregruzka:"<<endl;
   b=a.operator >(b);
   cout<<endl<<endl;
   cout<<"object 1:  ";
   a.printValue();
   cout<<endl<<endl;
   cout<<"object 2:  ";
   b.printValue();
   cout<<endl<<"______________________________________________"<<endl;
 
   cout<<endl<<endl<<"ZADANIE 3"<<endl<<endl;
   VectorProizvodny obj1;
   obj1.set(21);
   cout<<endl;
   obj1.clear();
   cout<<endl;
   obj1.print();
   getch();
   return 0;
}
//---------------------------------------------------------------------------
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.05.2015, 21:12
Помогаю со студенческими работами здесь

Создать класс Vector (вектор целых чисел)
Создать класс Vector (вектор целых чисел), переопределить для него операции: а) &quot;+=&quot; - сложение векторов с сохранением значения...

Класс "Массив длинных целых чисел"
1. Создать класс, содержащий динамический массив конечного размера. Тип массива - Массив длинных целых чисел. Класс должен содержать...

Разработать процедуру, которая формирует вектор из заданного количества целых случайных чисел
Разработать процедуру, которая формирует вектор из заданного количества целых случайных чисел, попадающих в указанный диапазон. Среди...

Разработать класс А, одной из компонент которого является вектор чисел
Разработать класс А, одной из компонент которого является вектор чисел и класс В, одним из методов которого является функция, выполняющая...

Разработать класс, одной из компонент которого является вектор чисел
Нужно написать прогу, сам пытался но не смог. (желательно с обьяснением) Заранее спасибо! Разработать класс А, одной из компонент...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru