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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Anastasiya_1692
1 / 1 / 1
Регистрация: 30.12.2009
Сообщений: 53
#1

Перегрузка оператора ~ - C++

03.02.2011, 18:05. Просмотров 710. Ответов 2
Метки нет (Все метки)

Доброго времени суток! Помогите пожалуйста с решением задачи.

Описать класс множество целых чисел. Перегрузить следующую операцию: ~ объединение множеств.
(т.е. mnozh3=mnozh1~mnozh2 означает, что множество mnozh3 состоит из элементов множеств mnozh1 и mnozh2).

Под множеством понимается одномерный массив не содержащий повторяющихся элементов. Например, [1 2 3 ] - множество, [1 2 2 3] - не является множеством, т.к. содержит две 2.

У меня получилось сформировать множество, а вот с объединением проблема...
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
#include <iostream.h>
#include <vcl.h>
#include <conio.h>
 
class set{
    public:
        set():n(0), mas(0){
            cout<<"\set constructed (contains 0 elements)\n\n";
        }
        ~set(){
            delete[] mas;
            cout<<"\set destructed\n";
        }
 
        int size(){
         return n;
        }
 
        void print (void){
          cout<<"\nsize of set= "<<size()<<"\n";
          for(int i=0;i<size();i++)
          cout<<mas[i]<<"  ";
        }
 
        set& operator+(int new_el){
            for(int i=0;i<n;i++)
                if(mas[i]==new_el){
                 cout<<"not added: "<<new_el<<"\n\n";
                 return *this;
                }
            int* temp=new int[n+1];
            for(int i=0;i<n;i++) temp[i]=mas[i];
            temp[n]=new_el;
            ++n;
            delete[] mas;
            mas=temp;
            cout<<"added: "<<new_el<<"\n\n";
            return *this;
        }
 
    private:
        int n;
        int *mas;
};
 
int main(){
int i,k,el;
    set a;
    cout<<"Enter number of added elements: ";
    cin>>k;
 
    for (i=0; i<k; i++){
     cin>>el;
     a+el;
    }
 
    a.print();
        getch();
}
Большое спасибо всем за помощь!!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.02.2011, 18:05     Перегрузка оператора ~
Посмотрите здесь:

Перегрузка оператора ^ - C++
Здравствуйте! Необходимо перегрузить бинарный оператор ^ для транспонирования матрицы. Есть класс матрицы: template &lt;class T&gt; class...

Перегрузка оператора % - C++
Подскажите пожалуйста как перегрузить оператор % для матрицы! #include &quot;StdAfx.h&quot; #include &quot;statik.h&quot; #include &lt;iostream&gt; ...

Перегрузка оператора << - C++
Код класса: #include &lt;iostream&gt; #include &lt;cstdlib&gt; #include &lt;cassert&gt; #ifndef ARRAY_H #define ARRAY_H template&lt; class...

Перегрузка оператора + - C++
Вот заголовочный файл // Заголовочный файл Vector.h #ifndef VECTOR_H #define VECTOR_H #include &lt;iostream&gt; using namespace...

Перегрузка оператора -- - C++
Добрый день, у меня возникла небольшая проблема. Дело в том, что display() работает нормально. Только я не могу понять, что нужно сделать,...

Перегрузка оператора == - C++
нужно сравнить 1) объект класса abc с объектом класса abc1 2) объект класса abc с другим объектом класса abc 3) объект класса abc1...

Перегрузка оператора == - C++
Есть шаблонный класс List (не имеющий перегруженных операторов) и есть шаблонный класс ListWithName, который наследует List и из своих...

Перегрузка оператора ++ - C++
#include &quot;Operation.h&quot; using namespace std; const int COUNT = 10; int _tmain(int argc, _TCHAR* argv) { srand((unsigned...

Перегрузка оператора + - C++
Написал для перегрузки оператора + class BoolMatrix { private: int feet; public: BoolMatrix(int f): feet(f) {} ...

Перегрузка оператора + - C++
Доброго времени суток. Есть программа, создающая связный список, который содержит числа по возрастанию #include &lt;iostream&gt; enum...

Перегрузка оператора == и др - C++
C++ Builder ругаеться на перегрузку операторов. На mingw32-g++ все компилилось нормально. Пример пергрузки взял с хабра описание...

Перегрузка оператора () - C++
Привет всем помогите придумать способ реализаци следущей задачи: есть класс симметричная матрица: class Matrix { ...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Somebody
2786 / 1600 / 145
Регистрация: 03.12.2007
Сообщений: 4,190
Завершенные тесты: 1
03.02.2011, 20:44     Перегрузка оператора ~ #2
~ никак, она унарная, можно + перегрузить
igorrr37
1644 / 1272 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
03.02.2011, 21:16     Перегрузка оператора ~ #3
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
#include <iostream>
using namespace std;
 
class set{
    public:
        set():n(0), mas(0){cout<<"\nset constructed (contains 0 elements)\n\n";}
        set(const set&);
        ~set(){
            delete[] mas;
            cout<<"\nset destructed\n";
        }
        int size(){return n;}
        void print (void);
        set& operator=(const set&);
        set& operator+(int);
        set unite(const set&);
    private:
        int n;
        int *mas;
};
 
set::set(const set& x){
    n=x.n;
    mas=new int[n];
    for(int i=0;i<n;i++) mas[i]=x.mas[i];
}
 
void set::print(){
    cout<<"\nsize of set= "<<size()<<"\n";
    for(int i=0;i<size();i++)
    cout<<mas[i]<<"  ";
}
 
set& set::operator=(const set& x){
    if(this==&x) return *this;
    delete[] mas;
    n=x.n;
    mas=new int[n];
    for(int i=0;i<n;i++) mas[i]=x.mas[i];
    return *this;
}
 
set& set::operator+(int new_el){
    for(int i=0;i<n;i++)
        if(mas[i]==new_el){
         cout<<"not added: "<<new_el<<"\n\n";
         return *this;
        }
    int* temp=new int[n+1];
    for(int i=0;i<n;i++) temp[i]=mas[i];
    temp[n]=new_el;
    ++n;
    delete[] mas;
    mas=temp;
    cout<<"added: "<<new_el<<"\n\n";
    return *this;
}
 
set set::unite(const set& x){
    set temp=*this;
    for(int i=0; i<x.n; i++){
        temp+x.mas[i];
    }
    return temp;
}
 
int main(){
    set a, b, c;
    a+1+2+3;
    b=a;
    b+44+55;
    c=a.unite(b);     // объединение
    b=a+100;
    c.print();
}
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru