c++中如何求两个set的差集_c++ set差集方法

使用std::set_difference可求两个set的差集,需包含头文件,输入set自动有序,输出容器需预分配空间或使用inserter;示例中set1与set2的差集为{1,2},结果存入vector或set;自定义类型需重载

c++中如何求两个set的差集_c++ set差集方法

在C++中,求两个set的差集可以使用标准库中的std::set_difference算法。这个函数定义在algorithm头文件中,用于计算两个有序序列的差集,即属于第一个集合但不属于第二个集合的元素。

使用 set_difference 求差集

步骤说明:

std::set本身是有序容器,天然满足set_difference对有序输入的要求。 调用std::set_difference时,需要提供两个输入区间的迭代器和一个输出迭代器。 结果会写入到指定的输出容器中,比如另一个setvector

示例代码:

#include iostream>
#include
#include
#include
int main() {
    std::set set1 = {1, 2, 3, 4, 5};
    std::set set2 = {3, 4, 5, 6, 7};

    std::vector difference;
    // 预分配空间,避免多次扩容
    difference.resize(set1.size());

    auto it = std::set_difference(
        set1.begin(), set1.end(),
        set2.begin(), set2.end(),
        difference.begin()
    );

    // 调整大小以去除未使用的部分
    difference.erase(it, difference.end());

    std::cout     for (const auto& elem : difference) {
        std::cout     }
    std::cout
    return 0;
}

输出结果:
差集: 1 2

注意事项

std::set_difference要求输入区间已排序,而std::set自动有序,因此可直接使用。 输出容器需提前分配足够空间,否则可能导致未定义行为。 若希望结果仍为set类型,可将结果插入新的std::set,或直接用inserter避免手动管理空间。

更简洁的写法(使用 inserter):

立即学习“C++免费学习笔记(深入)”;

std::set result;
std::set_difference(
    set1.begin(), set1.end(),
    set2.begin(), set2.end(),
    std::inserter(result, result.begin())
);

自定义类型的差集

如果set中存储的是自定义类型,需确保该类型支持比较操作(即定义了运算符),或者传入相应的比较函数。

例如:

struct Person {
    int id;
    std::string name;
};
bool operator    return a.id }

只要重载了,就可以像基本类型一样使用set_difference

基本上就这些。只要包含头文件、正确使用迭代器和输出容器,就能高效求出两个set的差集。

以上就是c++++中如何求两个set的差集_c++ set差集方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1478149.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 02:40:28
下一篇 2025年12月19日 02:40:36

相关推荐

发表回复

登录后才能评论
关注微信