Бинарный поиск C ++ STL - PullRequest
       5

Бинарный поиск C ++ STL

18 голосов
/ 26 ноября 2010

У меня есть вектор unordered_map, который отсортирован по определенной мной функции сравнения. Я хотел бы использовать бинарный поиск, чтобы найти одно из значений с помощью функции сравнения. Однако бинарный поиск возвращает только bool, и мне нужен индекс / итератор результата. Что я мог сделать?

Ответы [ 2 ]

22 голосов
/ 26 ноября 2010
#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
}
15 голосов
/ 26 ноября 2010
#include <algorithm>
using namespace std;

it = lower_bound(a.begin, a.end(), value, cmp);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...