c ++ stl使用比较谓词/仿函数与容器

时间:2018-04-18 04:17:01

标签: c++ arrays vector stl

几年后我还没有触及过C ++,所以请耐心等待。 我需要在其他容器的有序向量中进行二进制搜索,让我们说成对,但无论什么原因我都无法编译几行。

所以,对于初学者来说,编译很好:

bool cmp_pair( int l, int r )
{
    return l < r;
}

main ()
{
    vector<int> v;
    binary_search( v.begin(), v.end(), 0, cmp_pair );

  return 0;
}

但这并不是:

bool cmp_pair( const pair<int,int>& l, const pair<int,int>& r )
{
    return l.first < r.first;
}

main ()
{
    vector< pair< int, int > > v;
    binary_search( v.begin(), v.end(), 0, cmp_pair );

  return 0;
}

Functor没有帮助:

struct cmp_pair {
    bool operator()( const pair<int,int>& l, const pair<int,int>& r )
    {
        return l.first < r.first;
    }
};

main ()
{
    vector< pair< int, int > > v;
    binary_search( v.begin(), v.end(), 0, cmp_pair() );

  return 0;
}

1 个答案:

答案 0 :(得分:2)

由于你在对向量上进行二元搜索,所以第三个参数应该是对的,所以你的代码应该是这样的:

using namespace std;
bool cmp_pair( const pair<int,int>& l, const pair<int,int>& r )
{
    return l.first < r.first;
}

int main ()
{
    vector< pair< int, int > > v;
   if(binary_search( v.begin(), v.end(), std::make_pair(0,0), cmp_pair ))
   {
     std::cout<<"found...."<<std::endl;
   }
   else
   {
    std::cout<<"not found...."<<std::endl;
   }
  return 0;
}

比较器中存在同样的问题