[英]unexpected output from C++ multiset lower_bound
想知道为什么下面的代码返回1
? 我从不将1
插入multiset
容器。
#include <iostream>
#include <set>
int main ()
{
std::multiset<int> mymultiset;
std::multiset<int>::iterator itlow;
mymultiset.insert(-3);
itlow = mymultiset.lower_bound (3);
std::cout << *itlow << endl; // output 1
return 0;
}
mymultiset.lower_bound(3)
返回容器中3
可以到达的最低位置,即容器的末尾。 所以itlow
等于mymultiset.end()
,并且它mymultiset.end()
引用。 std::cout << *itlow
有未定义的行为。
您正在尝试获取下限为 3 且最大值为 -3 的迭代器。 所以你有一个结束迭代器,它的值是未定义的。 你应该使用multiset::begin()
作为你的迭代器,或者像itlow = mymultiset.lower_bound (-4);
这样的东西itlow = mymultiset.lower_bound (-4);
这不是很温和。
嗨,为了澄清我的理解,我有一个包含 1 和 5 的多重集。
mset.insert(1);
mset.insert(5);
auto it = s.lower_bound(6);
cout<<*it<<endl;
现在,从上面的答案中,我将得到 2,因为这是值 6 可以容纳在容器内的位置。 我说得对吗?
接下来,如果我搜索值 4,我会得到 5。在这里我认为迭代器没有到达 mset.end()。 我说得对吗?
谢谢
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.