多种二分查找

文章目录

二分查找

常规实现

java 复制代码
public static int binarySearch(int[]a,int target)
{
    int i=0,j=a.length-1;
    while(i<=j)
    {
        int m=i+((j-i)>>>1);
        if(target<a[m])
        {
            j=m+1;
        }
        else if(a[m]<target)
        {
            i=m-1;
        }
        if(target==a[m])
        {
            return m;
        }
    }
    return -1;
}

此时i和j所对应的元素都要参与比较运算,故循环条件为i<=j

改动版

java 复制代码
public static int binarySearch(int[]a,int target)
{
    int i=0,j=a.length;
    while(i<j)
    {
        int m=i+((j-i)>>>1);
        if(target<a[m])
        {
            j=m;
        }
        else if(a[m]<target)
        {
            i=m-1;
        }
        if(target==a[m])
        {
            return m;
        }
    }
    return -1;
}

**此时j表示边界,j指向的并不是查找目标,故循环条件为i<j,且j=m

平衡版

改进之前二分查找左边和右边所用时间不一样的情况

特点:左闭右开的区间,i指向的可能是目标,而j指向的不是目标
不在循环内找出,等循环范围只剩i时,在循环外面比较a[i]与target

java 复制代码
public static int binarySearch(int[]a,int target)
{
    int i=0,j=a.length;
    while(1<j-i)
    {
        int m=i+((j-i)>>>1);
        if(target<a[m])
        {
            j=m;
        }
        else
        {
            i=m;
        }

    }
    if(target==a[i])
    {
        return i;
    }
    return -1;
}

java中直接用Arrays类下的binarySearch方法进行查找,如果找到了返回目标的索引,没找到返回-(插入位置索引+1)

有重复元素时查找与目标相等的最靠左的索引

java 复制代码
public static int binarySearch(int[]a,int target)
{
    int i=0,j=a.length-1;
    while(i<=j)
    {

        int m=i+((j-i)>>>1);
        if(target<=a[m])
        {
            j=m-1;
        }
       else
        {
           i=m+1;
        }
    }
  return i;
}

找到最右边的元素

java 复制代码
public static int binarySearch(int[]a,int target)
{
    int i=0,j=a.length-1;
    while(i<=j)
    {

        int m=i+((j-i)>>>1);
        if(target<a[m])
        {
            j=m-1;
        }
        else if(a[m]<=target)
        {
            i=m+1;
        }
    }
    return i-1;
}
相关推荐
80530单词突击赢8 分钟前
C++关联容器深度解析:set/map全攻略
java·数据结构·算法
兩尛14 分钟前
c++知识点1
java·开发语言·c++
舟舟亢亢17 分钟前
JVM复习笔记——下
java·jvm·笔记
rainbow688918 分钟前
Python学生管理系统:JSON持久化实战
java·前端·python
有味道的男人32 分钟前
1688获得商品类目调取商品榜单
java·前端·spring
独自破碎E35 分钟前
【中心扩展法】LCR_020_回文子串
java·开发语言
不光头强36 分钟前
spring boot项目欢迎页设置方式
java·spring boot·后端
4311媒体网1 小时前
自动收藏功能的实现方法
java·开发语言
Yana.nice1 小时前
证书格式的适用场景与核心对比
java·linux