二分查找思路实现

二分查找是一种很常见的查找算法,重要的是边界的处理和循环的起止条件

  1. 使用二分查找的话,首先接收的数组一定是有序的。
  2. 确定边界。在头一次循环中,左边界也就是索引下标为0的位置,右边界是数组的长度-1.
  3. 确定循环起止条件。当左边界 l <= r 右边界时,循环成立。此时的l和r类似于双指针,指向数组的位置。在循环过程中没有找到目标值时,根据目标值和m的大小,再次确定左右边界的选取范围。当中间值 am == target 时,即找到目标值,返回目标值下标m。而当 l > r 时 也就代表着未找到数据,返回 -1;
  4. 注意点:在求m的大小时,可能会出现数据溢出的情况。正常情况 m = (l + r) / 2 向下取整。为了避免数据溢出(当数组长度很大时,并且数据处于数组中的右部分,有可能会出现数据溢出),我们可以使用右移一位的方式(位运算,等价于除以2,前提是正整数)。还可以使用 m = l + (r - l) / 2 ; 的方式避免数据过大造成溢出
  5. 代码如下:
java 复制代码
public static int binarySearch(int[] a, int t) {
        int l = 0, r = a.length - 1, m;
        while (l <= r) {
            m = (l + r) / 2;
            //m = (l + r) >>> 1;
            //m = l + (r - l) / 2;
            if (a[m] == t) {
                return m;
            } else if (a[m] > t) {
                r = m - 1;
            } else {
                l = m + 1;
            }
        }
        return -1;
    }
相关推荐
摇滚侠1 分钟前
Spring 零基础入门到进阶 入门 06-10
java·spring·intellij-idea
要开心吖ZSH4 分钟前
AI医疗分诊与健康咨询助手agent开发——(1)从零搭建SpringBoot与AI对话系统:后端骨架 + 前端对话页 + SSE流式输出
java·ai·agent·健康医疗
星恒随风5 分钟前
C++ 类和对象入门(三):拷贝构造、赋值运算符重载和深浅拷贝
开发语言·c++·笔记·学习
RickyWasYoung6 分钟前
【Matlab】科研绘图配色-极简版
开发语言·matlab
biubiubiu07066 分钟前
SpringBoot生产级日志配置
java·spring boot·后端
凡人叶枫7 分钟前
Effective C++ 条款03:尽可能使用 const
linux·开发语言·c++·嵌入式开发
光影62713 分钟前
Python接口自动化测试----Requests库基础入门
开发语言·python·测试工具·pycharm·自动化
程序媛_13 分钟前
【Python】连接PostgreSQL获取手机验证码
开发语言·python·postgresql
ch.ju15 分钟前
Java Programming Chapter 4——Inherited call
java·开发语言
是有头发的程序猿18 分钟前
竞品分析 + 用户洞察自动化|基于 item_review 评论接口 + 多 AI Agent 实现淘宝评论全量采集与智能分析(附python源码)
java·python·自动化