二进制搜索C++ STL

Ste*_*eng 18 c++ stl

我有一个unordered_map向量,它根据我定义的比较器函数进行排序.我想使用二进制搜索来使用比较器函数查找其中一个值.但是,二进制搜索只返回bool,我需要结果的索引/迭代器.我能做什么?

T33*_*33C 22

#include <algorithm>
using namespace std;

//!!!!!   a must be sorted using cmp. Question indicates that it is.        
it = lower_bound(a.begin, a.end(), value, cmp);

//Check that we have actually found the value. 
//If the requested value is missing
//then we will have the value before where the requested value 
//would be inserted.
if(it == a.end() || !cmp(*it, value))
{
   //element not found
} 
else
{
   //element found
}
Run Code Online (Sandbox Code Playgroud)

  • lower_bound似乎比简单的"任何匹配值"慢得多.假设{1,2,3,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5, 5,5,6,7}.中间是5 - 寻求价值.但是lower_bound将会离开.这是不理想的.我可以假设找到左边界的O(Log(N))解.但这是多余的.我对此非常不满.但是有一个C函数:: bsearch. (2认同)

Teo*_*oae 15

#include <algorithm>
using namespace std;

it = lower_bound(a.begin, a.end(), value, cmp);
Run Code Online (Sandbox Code Playgroud)

  • +1或可能是upper_bound或equal_range (3认同)
  • -1 lower_bound不一定会返回该元素.如果元素缺失,它将返回元素,如果它在向量中. (2认同)
  • 使用 lower_bound 仍然是明智的。获取迭代器,检查它是否可取消引用。如果是,则取消引用它并检查搜索到的元素。如果它是元素,那么你就有它,否则它不在那里。 (2认同)