首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在C++中找到两个std::set的交集?

如何在C++中找到两个std::set的交集?
EN

Stack Overflow用户
提问于 2012-11-19 13:17:40
回答 4查看 95.8K关注 0票数 104

我一直试图在C++中查找两个std::set之间的交叉点,但是我总是得到一个错误。

我为此创建了一个小样本测试

代码语言:javascript
运行
复制
#include <iostream>
#include <vector>
#include <algorithm>
#include <set>
using namespace std;

int main() {
  set<int> s1;
  set<int> s2;

  s1.insert(1);
  s1.insert(2);
  s1.insert(3);
  s1.insert(4);

  s2.insert(1);
  s2.insert(6);
  s2.insert(3);
  s2.insert(0);

  set_intersection(s1.begin(),s1.end(),s2.begin(),s2.end());
  return 0;
}

后一个程序不会生成任何输出,但我希望有一个新的集合(让我们称其为s3),其中包含以下值:

代码语言:javascript
运行
复制
s3 = [ 1 , 3 ]

相反,我得到的是错误:

代码语言:javascript
运行
复制
test.cpp: In function ‘int main()’:
test.cpp:19: error: no matching function for call to ‘set_intersection(std::_Rb_tree_const_iterator<int>, std::_Rb_tree_const_iterator<int>, std::_Rb_tree_const_iterator<int>, std::_Rb_tree_const_iterator<int>)’

我对这个错误的理解是,在set_intersection中没有接受Rb_tree_const_iterator<int>作为参数的定义。

此外,我假设std::set.begin()方法返回这种类型的对象,

在C++中有没有更好的方法来找到两个std::set的交集?最好是一个内置的函数?

非常感谢!

EN

Stack Overflow用户

发布于 2012-11-19 13:22:38

参见std::set_intersection。您必须添加一个输出迭代器,您将在其中存储结果:

代码语言:javascript
运行
复制
#include <iterator>
std::vector<int> s3;
set_intersection(s1.begin(),s1.end(),s2.begin(),s2.end(), std::back_inserter(s3));

完整列表请参见Ideone

票数 7
EN
查看全部 4 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13448064

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档