如何检查 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&amp; 作为参数类型(例如,否则你不能传递 const 左值)。 糟糕,我一直忘记 const 是为类类型推断的。不过,UnorderedSet const&amp;也可以接受左值和右值,并且更清楚地表示参数没有改变。

以上是关于如何检查 unordered_set 是不是重叠?的主要内容,如果未能解决你的问题,请参考以下文章

如何检查时间跨度是不是与其他时间跨度重叠[重复]

地理位置 - 如何检查 2 个圆圈是不是重叠

我们如何检查唯一 ID 的任意 2 个间隔是不是重叠?

JavaScript 检查时间范围是不是重叠

检查 UI 元素/RectTransform 是不是重叠

如何检测小部件是不是在堆栈中重叠?