【二分查找】

前提:在一个已序的空间中查找

注意:查找边界条件

情况一:左闭右开 【 ),右边界始终无法取到

假如前开后闭空间 【left,right),比如int array[10]={0,1,2,3,4,5,6,7,8,9};【0,10)

int BinarySearch (int a[],int size,int data)

{

   int left=0;

   int right=size;

   int mid=0; 

   while(left<right)//注意此处不能去等号

     {

        mid=left + (right-left)/2;

        if(data<a[mid])

           {

             right=mid;

           }

        else if(data>a[mid])

           {

             left=mid+1;

           }

        else

           {

             return mid;

           }

     }

     return -1;

}

假如查找3

1 2 3 4 5 6 7 8 9

第一次 【1,9) mid=4 a[4]>3 缩小右边界 [0,4)

        即直接right=mid;

第二次 【0,4) mid=2 a[2]==3 退出

假如找9

第一次 【0,9) mid=4 a[4]<9 改变左边界[5,9)

第二次 【5,9)mid=9 a[7]<9 改变左边界[8,9)

第三次 【8,9)mid=8 a[8]==9 退出

情况二:左闭右闭 右边界可以取到

假如前开后闭空间 【left,right】,比如int array[10]={0,1,2,3,4,5,6,7,8,9};【0,9】

int BinarySearch (int a[],int size,int data)

{

   int left=0;

   int right=size;

   int mid=0; 

   while(left<right)//注意必须加=号,比如查找最后一个元素

     {

        mid=left + (right-left)/2;

        if(data<a[mid])

           {

             right=mid-1;

           }

        else if(data>a[mid])

           {

             left=mid+1;

           }

        else

           {

             return mid;

           }

     }

     return -1;

}

假如查找4

1 2 3 4 5 6 7 8 9

第一次 [0,8] mid =4 a[4]>4  缩小右边界[0,3]

第二次 [0,3] mid =1 a[1]<4  改变左边界[2,3]

第三次 [2,3] mid=2  a[2]<4  改变左边界[3,3]

第四次 [3,3] mid=3