为什么 差集后只有3个元素?

sdchenchen2012 2013-02-27 02:52:07

int main () {
int first[] = {5,10,15,20,25};
int second[] = {50,40,30,20,10};
std::vector<int> v(10); // 0 0 0 0 0 0 0 0 0 0
std::vector<int>::iterator it;

std::sort (first,first+5); // 5 10 15 20 25
std::sort (second,second+5); // 10 20 30 40 50

it=std::set_difference (first, first+5, second, second+5, v.begin());
// 5 15 25 0 0 0 0 0 0 0
v.resize(it-v.begin()); // 5 15 25

std::cout << "The difference has " << (v.size()) << " elements:\n";
for (it=v.begin(); it!=v.end(); ++it)
std::cout << ' ' << *it;
std::cout << '\n';

return 0;
}

这是一个例子,运行的结果v中

The difference has 3 elements:
5 15 25

只有3个元素,为什么?

不是应该有5个吗?


多谢
...全文
174 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
bladelyer 2013-02-27
  • 打赏
  • 举报
回复
resize带一个元素个数参数,设置集合保留的元素个数(从第一个开始),剩余的将被抹除。it指向25后面的0,it与v.begin之间存在三个元素(不包括it所指元素本身),所有resize参数就是三个元素,剩余7个元素将被抹除。
billzheng 2013-02-27
  • 打赏
  • 举报
回复
Notice that this is a directional operation - for a symmetrical equivalent, see set_symmetric_difference http://www.cplusplus.com/reference/algorithm/set_symmetric_difference/
healer_kx 2013-02-27
  • 打赏
  • 举报
回复
引用 3 楼 sdchenchen2012 的回复:
引用 1 楼 rocktyt2 的回复:为什么要有5个?你理解差集的含义了吗 不理解啊
通俗的说就是A集合有的,而B集合没有的。
bladelyer 2013-02-27
  • 打赏
  • 举报
回复
set_difference后面有行注释“ // 5 15 25 0 0 0 0 0 0 0”已经解释了v所存储的内容,set_difference返回的迭代器it是25后面这个元素。 resize是重设大小,参数是元素个数,抹除了后没的7个元素,再求v.size自然是3
sdchenchen2012 2013-02-27
  • 打赏
  • 举报
回复
引用 1 楼 rocktyt2 的回复:
为什么要有5个?你理解差集的含义了吗
不理解啊
fishion 2013-02-27
  • 打赏
  • 举报
回复
Unites all of the elements that belong to one sorted source range, but not to a second sorted source range, into a single, sorted destination range, where the ordering criterion may be specified by a binary predicate.
rocktyt 2013-02-27
  • 打赏
  • 举报
回复
为什么要有5个?你理解差集的含义了吗

65,210

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧