多种二分查找

文章目录

二分查找

常规实现

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;
}
相关推荐
极客先躯2 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户60648767188962 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java
我命由我123452 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
aXin_ya2 小时前
微服务第八天 Sentinel 四种分布式事务模式
java·数据库·微服务
Halo_tjn2 小时前
Java Set集合相关知识点
java·开发语言·算法
Linsk2 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
许彰午2 小时前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
zhouwy1132 小时前
Java 快速入门笔记:从基础语法到 Spring Boot 实战
java
极创信息3 小时前
信创产品认证怎么做?信创产品测试认证的主要流程
java·大数据·数据库·金融·软件工程
SamDeepThinking3 小时前
并发量就算只有2,该上锁还得上呀
java·后端·架构