多种二分查找

文章目录

二分查找

常规实现

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时,在循环外面比较ai与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;
}
相关推荐
人活一口气11 小时前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
像我这样帅的人丶你还13 小时前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端
NE_STOP14 小时前
vibe Coding -- 小项目实战
java
未秃头的程序猿19 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户2986985301420 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉20 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯20 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手20 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记20 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端
荣码20 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python