首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ >

为啥 差集后只有3个元素

2013-03-01 
为什么 差集后只有3个元素?int main () { int first[] {5,10,15,20,25} int second[] {50,40,30,20,1

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

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个吗?
 

多谢
 
[解决办法]
为什么要有5个?你理解差集的含义了吗
[解决办法]
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.

[解决办法]
set_difference后面有行注释“ //  5 15 25  0  0  0  0  0  0  0”已经解释了v所存储的内容,set_difference返回的迭代器it是25后面这个元素。
resize是重设大小,参数是元素个数,抹除了后没的7个元素,再求v.size自然是3
[解决办法]

引用:
引用:为什么要有5个?你理解差集的含义了吗
不理解啊


通俗的说就是A集合有的,而B集合没有的。
[解决办法]
Notice that this is a directional operation - for a symmetrical equivalent, see set_symmetric_difference

http://www.cplusplus.com/reference/algorithm/set_symmetric_difference/
[解决办法]
resize带一个元素个数参数,设置集合保留的元素个数(从第一个开始),剩余的将被抹除。it指向25后面的0,it与v.begin之间存在三个元素(不包括it所指元素本身),所有resize参数就是三个元素,剩余7个元素将被抹除。

热点排行