STL二分查找

Posted TQCAI

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了STL二分查找相关的知识,希望对你有一定的参考价值。

实现源码:https://www.cnblogs.com/cobbliu/archive/2012/05/21/2512249.html


 

1.在一个递增的数组(或vector)中查找元素属于[ s , e ) 的下标

 

int main()
{
    const int n=10;
              //0 1 2 3 4 5 6 7 8 9
    int arr[n]={1,2,3,4,5,5,5,5,9,10};
    int s,e;
    I("%d%d",&s,&e);
    int s_pos=lower_bound(arr,arr+n,s)-arr;
    int e_pos=upper_bound(arr,arr+n,e)-arr;
    O("%d,%d\\n",s_pos,e_pos);
    return 0;
}

 


2.查找递增数组中元素是否存在

使用binary_search

 

注:

对于结构体,要么重载小于符号:

①bool operator<(const struct b) const

②要么定义有小于符号含义的cmp函数。

 


 3.应用在递减序列中

#include<cstdio> 
#include<stdlib.h> 
#include<algorithm>

using namespace std;

bool cmp(int x,int y){
    return x>y;
}

int main(){
    int asc[10]={0,1,2,3,4,5,6,7,8,9};
    int desc[10]={9,8,7,6,5,4,3,2,1,0};
    int obj=8;
    int p1=upper_bound(asc,asc+10,obj)-asc;
    int p2=upper_bound(desc,desc+10,obj,cmp)-desc;
    printf("%d,%d\\n",p1,p2) ;
    return 0;
}
View Code

 

以上是关于STL二分查找的主要内容,如果未能解决你的问题,请参考以下文章

分治算法——二分查找STL函数库的应用第五弹——二分函数

为啥 STL 的 next_permutation 实现不使用二分查找?

C++ STL中的二分查找

C++ STL中的Binary search(二分查找)

STL二分查找

STL二分算法