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

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

Войти
Регистрация
Восстановить пароль
 
Fnatick
0 / 0 / 0
Регистрация: 15.09.2013
Сообщений: 25
#1

Перегрузка функций - C++

23.05.2014, 09:28. Просмотров 286. Ответов 2
Метки нет (Все метки)

АТД - множество с элементами типа int. Дополнительно перегрузить следующие
операции:
«+» - добавить элемент в множество(типа int + set);
«–» - вычитание множеств (дружественная функция)
«==» - проверка множеств на равенство(дружественная функция).
Если меняю + на -, компилиться но сразу же ошибку
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
#include <iostream>
using namespace std;
 
class SetInt{
private:
    int *arr;
    int maxSize;
    int size;
public:
    SetInt(){
        maxSize = 0;
        size = 0;
        arr = NULL;
    }
    SetInt(int maxSize){
        this->maxSize = maxSize;
        size = 0;
        arr = new int[maxSize];
    }
    SetInt(const SetInt &setint){
        maxSize = setint.maxSize;
        arr = new int[maxSize];
        size = setint.size;
        for(int i = 0; i < size; i++)
            arr[i] = setint.arr[i];
    }
    ~SetInt(){
        delete [] arr;
    }
    
    bool in(int item){
        for(int i = 0; i < size; i++)
            if(arr[i]==item) return true;
        return false;
    }
    
    SetInt &operator += (int item){
        if(in(item)==false && size < maxSize){
            arr[size] = item;
            size++;
        }
        return *this;
    }
 
    SetInt &operator = (SetInt &setint){
        if(this == &setint) return *this;
        if(arr != NULL) delete [] arr;
        maxSize = setint.maxSize;
        arr = new int[maxSize];
        size = setint.size;
        for(int i = 0; i < size; i++)
            arr[i] = setint.arr[i];
        return *this;
    }
 
    bool operator == (SetInt &setint){
        if(size != setint.size) return false;
        // предварительно отсортировать arr и setchar.arr
        for(int i = 0; i < size; i++)
            if(arr[i]!=setint.arr[i]) return false;
        return true;
    }
 
    void input(int size){
        if(size > maxSize) return ;
        this->size = size;
        int i = 0;
        while(i < size){
            int item = (33 + rand()%100);
        //  cin >> item;
            if(!in(item)) {
                arr[i] = item;
                i++;
            }
        }   
    }
    
    void print(){
        for(int i = 0; i < size; i++)
            cout << arr[i] << " ";
        cout << endl;
    }
    friend SetInt operator + (SetInt &s1, SetInt &s2);
    friend SetInt operator * (SetInt &s1, SetInt &s2);
};
 
SetInt operator + (SetInt &s1, SetInt &s2){
    int maxTotalSize = s1.maxSize + s2.maxSize;
    SetInt result(maxTotalSize);    
    for(int i = 0; i < s1.size; i++){
        result.arr[i] = s1.arr[i];
    }
    result.size = s1.size;
    for(int i = 0; i < s2.size; i++){
        result += s2.arr[i];
    }
    return result;
}
 
SetInt operator * (SetInt &s1, SetInt &s2){
    int mSize;
    if(s1.maxSize > s2.maxSize) mSize = s1.maxSize; else mSize = s2.maxSize;
    SetInt result(mSize);
    for(int i = 0; i < s1.size; i++){
        for(int j = 0 ; j < s2.size; j++)
            if(s1.arr[i] == s2.arr[j])
                result += s1.arr[i];
    }
    return result;
}
 
int main(){
    srand(5);
    SetInt st(10);
    st.input(5);
    st.print();
 
    SetInt st2(10);
    st2.input(5);
    st2.print();
    
    if(st == st2) cout << "set equal" << endl;
    else cout << "set no equal" << endl;
 
    SetInt st1 = st2;
    if(st1 == st2) cout << "set equal" << endl;
    else cout << "set no equal" << endl;
 
    SetInt st3;
    st3 = st + st2;
    st3.print();
 
    
  
    st3 += 't';
 
 
    st3.print();
 
    SetInt st4;
    st4 = st*st2;
    cout <<"--------"<< endl;
    st4.print();
        int();
    system("pause");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.05.2014, 09:28     Перегрузка функций
Посмотрите здесь:

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

перегрузка функций - C++
Помогите: как изменится поле private, когда мы делаем перегрузку функции? Функция заполняет массив в зависимости от того, какого типа...

Перегрузка функций - C++
разработайте две версии функции F,заголовки которых выглядят следующим образом: 1) float F(float х); 2) void F (float x, float &amp;y); ...

Перегрузка функций - C++
Начал изучать (самостоятельно) С++ по книге Джесса Либерти &quot;Освой Срр самостоятельно за 21 день&quot;. Сейчас прохожу 5-ю главу и у меня...

Перегрузка функций - C++
Здравствуйте ув. программисты не могли бы мне кто нибуть написать простейшие примеры перегрузки +, -, логичное или , и умножения.

Перегрузка функций - C++
привет.только начал изучать С++.такая задача Написать реализацию перегруженных функций : int func(int* arr, int length, int number);...

Перегрузка функций - C++
С помощью механизма перегрузки функций организовать ввод с клавиатуры и сцепление: 1) одной строки и символа перевода на другую строку; ...

Перегрузка функций - C++
Задача: создать объект формирующий HTML теги. Теги бывают двух типов - полные &lt;p параметры_тега&gt;Текст абзаца&lt;/p&gt; и короткие &lt;input...

Перегрузка функций - C++
Здравствуйте!!! я не однократно просил помочь на этом форуме...именно с перегрузкой стека!!! Потому что все мои попытки самостоятельно...

Перегрузка функций - C++
Здравствуйте уважаемые програмисты:) У меня вот такое задание: В классе необходимо перегрузить нижеследующие операции, при этом две...

Перегрузка функций - C++
По заданию дано выражение V=М1&lt;&lt; М2 – где V- массив, а M1 и M2 - матрицы. Чтоб выполнить действие М1&lt;&lt; М2 из М1 и М2 нужно выбрать...

перегрузка функций - C++
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; class chisl { public: double x,y,z,a; void...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
nmcf
5240 / 4560 / 1532
Регистрация: 14.04.2014
Сообщений: 18,125
23.05.2014, 09:54     Перегрузка функций #2
Чтобы применять вычитание, надо перегрузку вычитания описать. Где она у тебя?
Fnatick
0 / 0 / 0
Регистрация: 15.09.2013
Сообщений: 25
23.05.2014, 10:09  [ТС]     Перегрузка функций #3
Ну вот я и не знаю как это сделать я думал там где оператор + , в самой функции там минус поставить ну и оператор поменять на -

Добавлено через 2 минуты
ну вот тут
C++
1
2
3
4
5
6
7
8
9
10
11
SetInt operator + (SetInt &s1, SetInt &s2){
    int maxTotalSize = s1.maxSize + s2.maxSize;
    SetInt result(maxTotalSize);    
    for(int i = 0; i < s1.size; i++){
        result.arr[i] = s1.arr[i];
    }
    result.size = s1.size;
    for(int i = 0; i < s2.size; i++){
        result += s2.arr[i];
    }
    return result;
Ответ Создать тему
Опции темы

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