set_symmetric_difference в C ++ с примерами

Опубликовано: 31 Декабря, 2021

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

Элементы сравниваются с помощью operator <для первой версии и comp для второй. Два элемента a и b считаются эквивалентными, если (! (A <b) &&! (B <a)) или if (! Comp (a, b) &&! Comp (b, a)).

Элементы в диапазонах уже должны быть заказаны.

1. Использование оператора по умолчанию <:

Синтаксис:

Template :
OutputIterator set_symmetric_difference (InputIterator1 first1, InputIterator1 last1,
                                         InputIterator2 first2, InputIterator2 last2,
                                         OutputIterator result);

Parameters :

first1, last1
Input iterators to the initial and final positions of the first
sorted sequence. The range used is [first1, last1), which contains
all the elements between first1 and last1, including the element
pointed by first1 but not the element pointed by last1.

first2, last2
Input iterators to the initial and final positions of the second
sorted sequence. The range used is [first2, last2).

result
Output iterator to the initial position of the range where the
resulting sequence is stored.
The pointed type shall support being assigned the value of an
element from the other ranges.

comp
Binary function that accepts two arguments of the types pointed
by the input iterators, and returns a value convertible to bool.
The function shall not modify any of its arguments.
This can either be a function pointer or a function object.

The ranges shall not overlap.

Return Type :
An iterator to the end of the constructed range.

Выход:

Первый массив содержит: 5 10 15 20 25
Второй массив содержит: 50 40 30 20 10

Симметричная разность состоит из 6 элементов:
 5 15 25 30 40 50

2. Использование пользовательской функции:

Synatx:

Шаблон :
OutputIterator set_symmetric_difference (InputIterator1 first1, InputIterator1 last1,
                                         InputIterator2 first2, InputIterator2 last2,
                                         Результат OutputIterator, Сравнить комп);

Параметры:

first1, last1, first2, last2, результат такой же, как описано выше.

комп
Двоичная функция, которая принимает два аргумента указанных типов
итераторами ввода и возвращает значение, конвертируемое в bool.
Функция не должна изменять ни один из своих аргументов.
Это может быть указатель на функцию или объект функции.

Диапазоны не должны перекрываться.

Тип возврата:
Итератор до конца построенного диапазона.
// CPP program to illustrate
// std :: set_symmetric_difference
#include <algorithm> // std::set_symmetric_difference, std::sort
#include <iostream> // std::cout
#include <vector> // std::vector
// Custom function
bool comp( int a, int b)
{
return a < b;
}
// Driver code
int main()
{
int first[] = { 5, 10, 15, 20, 25 };
int second[] = { 50, 40, 30, 20, 10 };
int n = sizeof (first) / sizeof (first[0]);
// Print first array
std::cout << "First array contains :" ;
for ( int i = 0; i < n; i++)
std::cout << " " << first[i];
std::cout << " " ;
// Print second array
std::cout << "Second array contains :" ;
for ( int i = 0; i < n; i++)
std::cout << " " << second[i];
std::cout << " " ;
std::vector< int > v(10);
std::vector< int >::iterator it, st;
// Sorting both the arrays
std::sort(first, first + 5);
std::sort(second, second + 5);
// Using default operator<
it = std::set_symmetric_difference(first, first + 5,
second, second + 5, v.begin(), comp);
std::cout << "The symmetric difference has "
<< (it - v.begin()) << " elements: " ;
for (st = v.begin(); st != it; ++st)
std::cout << ' ' << *st;
std::cout << ' ' ;
return 0;
}

Выход:

Первый массив содержит: 5 10 15 20 25
Второй массив содержит: 50 40 30 20 10

Симметричная разность состоит из 6 элементов:
 5 15 25 30 40 50

Возможное применение: используется для поиска элементов, которые присутствуют в одном контейнере, а не в другом.

1. Он используется для поиска списка студентов, которые не посещают оба класса. Учащиеся обоих классов присутствуют в списках.

// CPP program to illustrate
// std :: set_symmetric_difference
#include <bits/stdc++.h>
using namespace std;
int main()
{
// students attending first class
std::vector<string> class1{ "Samir" , "Manoj" , "Pranav" , "Rajesh" };
// students attending second class
std::vector<string> class2{ "Samir" , "Junaid" , "Manoj" , "Pankaj" , "Arpit" };
cout << "Students attending first class are : " ;
for ( auto i : class1) {
cout << i << " " ;
}
cout << " Students attending second class are : " ;
for ( auto i : class2) {
cout << i << " " ;
}
// to store the result of symmetric difference
std::vector<string> result(10);
std::vector<string>::iterator it;
// finding symmetric difference
it = set_symmetric_difference(class1.begin(),
class1.end(), class2.begin(), class2.end(), result.begin());
cout << " List of students that are not taking both classes :" ;
for (std::vector<string>::iterator i = result.begin(); i != it; i++) {
cout << *i << " " ;
}
return 0;
}

ВЫХОД :

Первый класс посещают следующие ученики: Самир Манодж Пранав Раджеш 
Второй класс посещают следующие ученики: Самир Джунаид Манодж Панкадж Арпит 

Список учеников, не посещающих оба класса: Джунаид Панкадж Арпит Пранав Раджеш 

2. Его также можно использовать для поиска номеров из обоих списков, которых нет в обоих списках.
Программа приведена выше.

Эта статья предоставлена Сачином Биштом . Если вам нравится GeeksforGeeks, и вы хотели бы внести свой вклад, вы также можете написать статью с помощью provide.geeksforgeeks.org или отправить ее по электронной почте на deposit@geeksforgeeks.org. Посмотрите, как ваша статья появляется на главной странице GeeksforGeeks, и помогите другим гикам.

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

Хотите узнать о лучших видео и практических задачах, ознакомьтесь с базовым курсом C ++ для базового и продвинутого уровня C ++ и курсом C ++ STL для базового уровня плюс STL. Чтобы завершить подготовку от изучения языка к DS Algo и многому другому, см. Полный курс подготовки к собеседованию .
C++