Java二分查找-图文

一、二分查找概念

      二分查找也叫折半查找,是在一组有序(升序/降序)的数据中查找一个元素,它是一种效率较高的查找方。

二、二分查找原理

1.二分查找的数组必须是有序数值型数组。

2.将想要查找的目标元素与查找范围内的中间元素进行比较,如果相等,查找结束,反之,把目标元素分到较大或者是较小的范围在进行比较。

3.通过分组可将查找范围缩小一半。

4.重复步骤二,直到目标元素与查找范围内中间元素相等或者没有这个目标元素,查找结束。        

 5.二分查找的时间复杂度O(log2n)

三、二分查找的具体步骤

前提:给定一个内含n个元素的有序数组A,满足A0<=A1<=A2<=·······<=An-1,一个待查值target,

           如果找到返回索引

           如果找不到返回索引-1

 1、设置i=0,j=n-1

 2、如果i>j,结束查找,没有找到,返回-1

 3、设置m为中间索引,则m=floor((i+j)/2), floor是向下取整(<=(i+j)/2 的最小整数)

 4、如果 target<Am ,设置j=m-1, 跳到第2步

 5、如果 Am< target,设置i=m+1, 跳到第2步

 6、如果 Am= target,结束查找,找到了!

 四、图示所示-基础版

查找target=4

 

 

 

编码


    /**
     * 二分查找基础版
     *
     * @param arr    查找升序数组
     * @param target 目标值
     * @return 找到返回索引
     * 找不到返回-1
     */
    public static int binarSearchBasic(int[] arr, int target) {
        //设置初值的索引
        int i = 0;
        int j = arr.length - 1;

        //循环
        while(i<=j){  //在范围内
		   int mid=(i+j)/2;
            //获取中间值
            if(target<arr[mid]){ //目标左边
                j=mid-1;
            }else if(arr[mid]<target){//目标右边
                i=mid+1;
            }else { //找到了
                return mid;
            }
        }
        return -1;
    }

 五、图示所示-改进版

 问题:对应(i+j)/2 有没有问题 ?

如果超过正整数最大值表示的范围,由正变负,发生错误!!

@Test
    public void main() {
        int i = 0;
        int j = Integer.MAX_VALUE - 1;
        int m = (i + j) / 2;
        System.out.println(m);  //1073741823
        //如果目标在右侧
        i = m + 1;
        System.out.println(i);  //1073741824
        System.out.println(j); //2147483646
        System.out.println(i+j); // -1073741826
//        m = (i + j) / 2;
        m = (i + j) >>>1;   //1610612735

        System.out.println(m);  //-536870913
        //此时发生错误:超过正整数能表示的范围,由正变负。
        //二进制数:
        //把java二进制数最高位为符号位,代表: -1073741826
        //不把二进制数最高位为符号位,代表:3221225470
    }

修改:无符号右移1位  >>> 1  ;  (可以使更多的语言) 

           m = (i + j) >>>1

查找target=13

 

 

 

 

 

 

编码

/**
     * 二分查找改动版
     *
     * @param arr    查找升序数组
     * @param target 目标值
     * @return 找到返回索引
     * 找不到返回-1
     */
    public static int binarSearchUpdate(int[] arr, int target) {
        //设置初值的索引
        int i = 0;
        int j = arr.length ; //第1处

        //循环
        while(i<j){  //第2处
            //中间值
            int mid=(i+j)>>>1;
            //获取中间值
            if(target<arr[mid]){ //目标左边
                j=mid;    //第3处
            }else if(arr[mid]<target){//目标右边
                i=mid+1;
            }else { //找到了
                return mid;
            }
        }
        return -1;
    }

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/352561.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python在线聊天室(带聊天保存)

python Socket在线聊天室(带聊天保存) 需求功能 1.聊天信息保存功能(服务端会把信息保存到一个txt里面) 2.使用pyqt5框架作为一个可视化界面 3.具备一个服务端和多个客户端的功能 4.具备离线加入黑名单(离线踢出) 5.具备在线加入黑名单(在线加入黑名单被踢出) 6.具备群聊功能…

任正非最新讲话:没有退路就是胜利之路!

内容来源&#xff1a;本文来自心声社区 组织管理 9月4日&#xff0c;华为心声社区发布了华为创始人任正非在华为高端技术人才使用工作组对标会上的讲话。 任正非表示&#xff0c;先有专才&#xff0c;才有全才&#xff0c;要实现跨界交流、融合创新&#xff0c;让领袖自然成长…

计算机网络——TCP协议

&#x1f4a1;TCP的可靠不在于它是否可以把数据100%传输过去&#xff0c;而是 1.发送方发去数据后&#xff0c;可以知道接收方是否收到数据&#xff1b;2.如果接收方没收到&#xff0c;可以有补救手段&#xff1b; 图1.TCP组成图 TCP的可靠性是付出代价的&#xff0c;即传输效率…

Git安装详细步骤

目录 1、双击安装包&#xff0c;点击NEXT​编辑 2、更改安装路径&#xff0c;点击NEXT 3、选择安装组件 4、选择开始菜单页 5、选择Git文件默认的编辑器 6、调整PATH环境 7、选择HTTPS后端传输 8、配置行尾符号转换 9、配置终端模拟器与Git Bash一起使用 10、配置额外…

内存管理(mmu)/内存分配原理/多级页表

1.为什么要做内存管理&#xff1f; 随着进程对内存需求的扩大&#xff0c;和同时调度的进程增加&#xff0c;内存是比较瓶颈的资源&#xff0c;如何更好的高效的利于存储资源是一个重要问题。 这个内存管理的需求也是慢慢发展而来&#xff0c;早期总线上的master是直接使用物…

【鸿蒙】大模型对话应用(一):大模型接口对接与调试

Demo介绍 本demo对接阿里云和百度的大模型API&#xff0c;实现一个简单的对话应用。 DecEco Studio版本&#xff1a;DevEco Studio 3.1.1 Release HarmonyOS API版本&#xff1a;API9 关键点&#xff1a;ArkTS、ArkUI、UIAbility、网络http请求、列表布局 官方接口文档 此…

玩转未来:Sui游戏峰会将于3月19日亮相GDC

Sui将在今年三月份的旧金山游戏开发者大会&#xff08;Game Developer Conference, GDC&#xff09;上推出其首个重大游戏活动&#xff0c;展示其为独立游戏到3A游戏提供动力&#xff0c;并为游戏开发人员开启吸引新玩家参与的能力。“Play Beyond&#xff1a;Sui游戏峰会”&am…

线程在操作系统以及java中的几种状态(源码分析)

操作系统中一般将线程划分为五种状态&#xff1a;新建、可运行&#xff08;就绪&#xff09;、运行、阻塞、终止 新建&#xff08;New&#xff09;&#xff1a;当一个线程被创建时&#xff0c;它处于新建状态。此时&#xff0c;线程对象已经创建&#xff0c;但还没有分配到CPU资…

element plus使用问题

文章目录 element plusvue.config.js注意1、有时候会报错 not a function2、使用 ElMessage 报错3、 element plus 版本过高4、警告Feature flag VUE_PROD_HYDRATION_MISMATCH_DETAILS is not explicitly defined.5、报错 ResizeObserver loop completed with undelivered noti…

网络基础---初识网络

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、局域网…

读取一个batch的图像并且显示出来

1读取一个batch用于训练 我们在训练模型的时候&#xff0c;除了观察图像的标签和尺寸&#xff0c;最好能读取一个batch的图像显示出来&#xff0c;观察原始图像和grountruth是否对应&#xff0c;如果正确才能正式开始后续的训练。 下面以一个皮肤病分割的数据集加以演示。 2…

保障接口安全的11个方法

一、参数校验 校验参数是否为空&#xff0c;有些接口中可能会包含多个参数&#xff0c;有些参数允许为空&#xff0c;有些参数不允许为空&#xff0c;需要对这些参数做校验&#xff0c;防止接口底层出现异常。校验参数类型&#xff0c;比如&#xff1a;age 是 int 类型的&…

对鸢尾花进行分类预测-----pycharm

项目说明 #项目&#xff1a; 对鸢尾花进行分类预测 #实例数量150个(3类各50个) #属性数量&#xff1a;4(数值型&#xff0c;数值型&#xff0c;帮助预测的属性和类) #特征&#xff1a;花萼长度&#xff0c;花萼宽度&#xff0c;花瓣长度&#xff0c;花瓣宽度 单位&#xff1…

HarmonyOS 鸿蒙组件启动规则(Stage模型)

组件启动规则&#xff08;Stage模型&#xff09; 启动组件是指一切启动或连接应用组件的行为&#xff1a; 启动UIAbility、ServiceExtensionAbility、DataShareExtensionAbility&#xff0c;如使用startAbility()、startServiceExtensionAbility()、startAbilityByCall()等相关…

FOC系列(五)----STM32F405RGT6控制板焊接与初步编写代码

声明&#xff1a;本人水平有限&#xff0c;博客可能存在部分错误的地方&#xff0c;请广大读者谅解并向本人反馈错误。    首先祝大家新年快乐&#xff0c;因为我也快放假了&#xff0c;驱动板只能是开学之后再去测试了&#xff0c;本篇博客应该是本专栏年前的最后一篇了 一…

【计网·湖科大·思科】实验三 总线型以太网的特性、集线器和交换机的区别、交换机的自学习算法

&#x1f57a;作者&#xff1a; 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux &#x1f618;欢迎关注&#xff1a;&#x1f44d;点赞&#x1f64c;收藏✍️留言 &#x1f3c7;码字不易&#xff0c;你的&#x1f44d;点赞&#x1f64c;收藏❤️关注对我真的很重要&…

字符串相关的函数和内存块相关函数

&#x1d649;&#x1d65e;&#x1d658;&#x1d65a;!!&#x1f44f;&#x1f3fb;‧✧̣̥̇‧✦&#x1f44f;&#x1f3fb;‧✧̣̥̇‧✦ &#x1f44f;&#x1f3fb;‧✧̣̥̇:Solitary-walk ⸝⋆ ━━━┓ - 个性标签 - &#xff1a;来于“云”的“羽球人”。…

[学习笔记] ONNX 基础知识

1. ONNX 简介 1.1 什么是 ONNX 开放神经网络交换 ONNX&#xff08;Open Neural Network Exchange&#xff09;是一套表示深度神经网络模型的开放格式&#xff0c;由微软和 Facebook 于 2017 推出&#xff0c;然后迅速得到了各大厂商和框架的支持。通过短短几年的发展&#xf…

【JavaEE进阶】 #{}和${}

文章目录 &#x1f343;前言&#x1f333;#{}和${}使⽤&#x1f6a9;Interger类型的参数&#xff08;基础数据类型&#xff09;&#x1f388;使用#{}&#x1f388;使用${} &#x1f6a9;String类型的参数使用&#x1f388;#{}使用&#x1f388;${} &#x1f38d;#{}和${}区别&a…

林浩然与极限的“无穷”约会

林浩然与极限的“无穷”约会 Lin Haoran’s Encounter with the Mathematical “Infinity” 在数学王国里&#xff0c;有一位名叫林浩然的大侠&#xff0c;他的江湖就是高等数学的殿堂。而他要挑战的终极Boss&#xff0c;便是那个既神秘又顽皮的“极限”。 In the kingdom of …