2 / 2 / 4
Регистрация: 08.09.2013
Сообщений: 94
1

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

12.05.2015, 20:12. Показов 1728. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.05.2015, 20:12
Ответы с готовыми решениями:

Создать класс длинных целых чисел
Создать класс длинных целых чисел. Класс имеет конструктор по умолчанию, конструктор -...

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

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

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

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

в 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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.05.2015, 21:12
Помогаю со студенческими работами здесь

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

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

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

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru