如何检查 unordered_set 是不是重叠?
Posted
技术标签:
【中文标题】如何检查 unordered_set 是不是重叠?【英文标题】:How to check unordered_set for overlaping?如何检查 unordered_set 是否重叠? 【发布时间】:2014-03-05 18:59:22 【问题描述】:我有两个 unordered_set,需要检查第一个的所有元素是否也是第二个的元素。
有没有一种快速的方法可以做到这一点,还是我应该使用另一个容器?
【问题讨论】:
IIRC 无法从unordered_map
中获取元素的散列键。因此,您必须重新散列每个元素。
我认为这些集合的大小不同,对吧?否则你可以使用operator==
。
【参考方案1】:
只需使用循环(或相应的算法)。复杂性与要测试的范围大小(近似)呈线性关系。
template <typename UnorderedSet, typename Iterator>
bool contains_all(UnorderedSet&& set, Iterator first, Iterator last)
using value_type = std::iterator_traits<Iterator>>::value_type;
return std::all_of(first, last, [&set] (const value_type& value)
return set.count(value);
);
【讨论】:
这需要 C++14。将auto
替换为 Type
以使其编译为 C++11。
+1,我建议将其重命名为 unordered_includes
以模仿用于有序输入的 std::includes
。我也会给它 4 个迭代器作为参数而不是 2 个容器。
更改其中一个容器的类型可以提高性能吗?
我会使用 UnorderedSet const&
作为参数类型(例如,否则你不能传递 const 左值)。
糟糕,我一直忘记 const
是为类类型推断的。不过,UnorderedSet const&
也可以接受左值和右值,并且更清楚地表示参数没有改变。以上是关于如何检查 unordered_set 是不是重叠?的主要内容,如果未能解决你的问题,请参考以下文章