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

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

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

Реализовать функцию вычисления симметричной разности множеств - C++

31.03.2016, 18:37. Просмотров 182. Ответов 4
Метки нет (Все метки)

Помогите пожалуйста, не знаю как симметрическую разность сделать. Должно вывести 0 1 7 8 9 15 40
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
#include <iostream>
 
int s_union(const int* a1, int n1, const int* a2, int n2, int* a3);
int s_intersect(const int* a1, int n1, const int* a2, int n2, int* a3);
int s_diff(const int* a1, int n1, const int* a2, int n2, int* a3);
 
int main(void){
int a[5] = { 1, 2, 7, 8, 10 };
int b[6] = { 0, 2, 9, 10, 15, 40 };
int c[11], n;
 
n = s_union(a, 5, b, 6, c);
for(int i = 0; i < n; i++)
std::cout << c[i] << ' ';
std::cout << std::endl;
 
n = s_intersect(a, 5, b, 6, c);
for(int i = 0; i < n; i++)
std::cout << c[i] << ' ';
std::cout << std::endl;
 
n = s_diff(a, 5, b, 6, c);
for(int i = 0; i < n; i++)
std::cout << c[i] << ' ';
return 0;
}
 
 
 
 
 
//объединение множеств
int s_union(const int* a1, int n1, const int* a2, int n2, int* a3){
const int* e1 = a1 + n1;
const int* e2 = a2 + n2;
int* p = a3;
 
while((a1 != e1) && (a2 != e2)) {
if(*a1 < *a2)
*p++ = *a1++;
else if(*a2 < *a1)
*p++ = *a2++;
else {
*p++ = *a1;
++a1;
++a2;
}
}
 
while(a1 != e1)
*p++ = *a1++;
while(a2 != e2)
*p++ = *a2++;
 
return (p - a3);
}
 
 
 
// пересечение множеств
int s_intersect(const int* a1, int n1, const int* a2, int n2, int* a3){
const int* e1 = a1 + n1;
const int* e2 = a2 + n2;
int* p = a3;
while((a1 != e1) && (a2 != e2)) {
if(*a1 < *a2)
*a1++;
else if(*a2 < *a1)
*a2++;
else {
*p++ = *a1;
++a1;
++a2;
}
}
return (p - a3);
}
 
 
 
// разность множеств
int s_diff(const int* a1, int n1, const int* a2, int n2, int* a3){
const int* e1 = a1 + n1;
const int* e2 = a2 + n2;
int* p = a3;
while((a1 != e1) && (a2 != e2)) {
if(*a1 < *a2)
*p++ = *a1++;
else if(*a2 < *a1)
++a2;
else {
++a1;
++a2;
}
}
return (p - a3);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.03.2016, 18:37
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Реализовать функцию вычисления симметричной разности множеств (C++):

Количество элементов в разности множеств - C++
Всем привет. Знаю, что тема довольно заезженная. Пролистал похожие на форуме, но решил все-таки создать свою. Итак, есть задание. На...

Ошбика в алгоритме нахождения разности множеств - C++
Set&amp; Set::operator-(const Set &amp;set) { Set *raznost = new Set; if (this-&gt;size != 0 &amp;&amp; set.size != 0) { for (int i = 0; i &lt;...

Реализовать рекурсивную функцию вычисления степени из числа - C++
Добрый день , помогите решить задачи : ==================================================================================== ...

Реализовать функцию для вычисления выражения по заданной формуле - C++
Составьте программу вычисления числа сочетаний из N по М. Число сочетаний определяется по формуле: с=n!/m!*(n-m)! , где n!=1∙2∙3∙…∙n....

Написать программу, в которой реализовать функцию вычисления синуса - C++
В общем решаю задачи по книге в с++ В главе был разобран пример функции, для вычисления гиперболического синуса по формуле: sh(x) =...

Реализовать рекурсивную функцию для вычисления значений функции - C++
Реализовать рекурсивную функцию для вычисления значений функции. Я не понимаю что и как с этой системой делать! P.S. &quot;якщо&quot; по русски...

4
yrceus
82 / 82 / 54
Регистрация: 25.08.2013
Сообщений: 326
31.03.2016, 20:12 #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
#include <iostream>
#include <algorithm>
#include <vector>
#include <iterator>
 
using namespace std;
 
void dif_many_sym(vector<int> *stn_1, vector<int> *stn_2, vector<int> *from) {
    remove_copy_if(stn_1->begin(), stn_1->end(), back_inserter(*from), [stn_2](int &i) ->bool {
        if (find(stn_2->begin(), stn_2->end(), i) != stn_2->end())
            return true;
        else
            return false;
    });
    if (!from->empty() && find(stn_2->begin(), stn_2->end(), from->front()) == stn_2->end()) 
        dif_many_sym(stn_2, stn_1, from);   
}
int main()
{
    vector<int> stn1 = { 1, 2, 7, 8, 10 }, stn2 = {0, 2, 9, 10, 15, 40}, dif;   
    dif_many_sym(&stn1, &stn2, &dif); 
    for (auto &i : dif)
        cout << i << ' ';
    return 0;
}
0
Veorirac
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 89
31.03.2016, 20:56  [ТС] #3
А попроще никак?

Добавлено через 6 минут
Мне же нужно это в мой код запихнуть
0
yrceus
82 / 82 / 54
Регистрация: 25.08.2013
Сообщений: 326
31.03.2016, 21:08 #4
Да тут как раз гораздо проще, две библиотечные функции поиска и вектор. С массивами нет желания возиться

Добавлено через 2 минуты
Пару тройку страниц прочитать про библиотечные контейнеры и
0
Veorirac
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 89
31.03.2016, 22:14  [ТС] #5
Ну тогда придется и начальный код переделывать, тут через вектора, а там через массивы, не хорошо как-то
0
31.03.2016, 22:14
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.03.2016, 22:14
Привет! Вот еще темы с ответами:

Реализовать функцию вычисления суммы элементов заданного диапазона - C++
Функция вычисления суммы элементов диапазона .

Реализовать функцию вычисления произведения и частного двух вещественных чисел - C++
Помогите пожалуйста

Реализовать функцию для вычисления тригонометрического выражения по заданной формуле - C++
Добрый день, по условию (фото) я составил функцию,но выдается ошибка,в чем проблемка:? #include &quot;stdafx.h&quot; #include &lt;iostream&gt; ...

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


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

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

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