Метод библиотеки C++ для пересечения двух unordered_setC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Метод библиотеки C++ для пересечения двух unordered_set

Сообщение Anonymous »

У меня есть два unordered_set, и мне нужно их пересечение. Я не могу найти библиотечную функцию для этого.
По сути, мне нужно следующее:

Код: Выделить всё

unordered_set a = {1, 2, 3};
unordered_set b = {2, 4, 1};

unordered_set c = a.intersect(b); // Should be {1, 2}
Я могу сделать что-то вроде

Код: Выделить всё

unordered_set c;
for (int element : a) {
if (b.count(element) > 0) {
c.insert(element);
}
}
Однако я думаю, что должен быть более удобный способ сделать это. Если его нет, может кто-нибудь объяснить, почему? Я знаю, что есть std::set_intersection, но, похоже, он работает только с векторами.

Подробнее здесь: https://stackoverflow.com/questions/481 ... rdered-set
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»