力扣704/35/34:二分查找

考虑到线性查找法的时间复杂度较高(O(n)), 我们可以选择使用二分查找算法.

二分查找算法只适用于有序数组(线性查找不需要满足该前提), 其时间复杂度为O(logn), 我们可以选择两种方式来完成二分查找算法.

要求 : 给定一个有序整形数组, 在该数组中, 找到目标值target, 如果找到, 则返回其在数组中的索引, 否则返回-1.

(1)方法1 : 指针左闭右闭[i, j]----> 推导出循环条件 : i <= j

public static int BinarySearch_1(int[] arr, int target) {int i = 0;int j = arr.length - 1;//设置指针和初值while (i <= j) {int mid = i + (j - i) / 2;if (arr[mid] == target) {return mid;} else if (arr[mid] < target) {i = mid + 1;} else {j = mid - 1;}}return -1;}

方式2 : 指针左闭右开[i, j) -----> 推导出循环条件 : i < j

public static int BinarySearch_2(int[] arr, int target) {int i = 0;int j = arr.length;while (i < j) {int mid = i + (j - i) / 2;if (arr[mid] > target) {j = mid;} else if (arr[mid] < target) {i = mid + 1;} else {return mid;}}return -1;}

test : 

@Testpublic void test1() {int[] arr = {1, 4, 6, 9, 11, 15, 57};int target = 9;int index1 = BinarySearch_1(arr, target);System.out.println("索引处是" + index1);int index2 = BinarySearch_2(arr, target);System.out.println("索引处是" + index2);}控制台 : 
索引处是3
索引处是3

而对于有重复性元素的数组来说, 查找值恰好为该重复的元素值, 上面两种方式返回的索引即为第一次被查找到的索引位置,.

test : 

@Testpublic void test1() {int[] arr = {9, 9, 9, 9, 9, 9};int target = 9;int index1 = BinarySearch_1(arr, target);System.out.println("索引处是" + index1);int index2 = BinarySearch_2(arr, target);System.out.println("索引处是" + index2);}控制台 : 
索引处是2
索引处是3

如果我们要求返回的索引是重复元素最左边的位置的索引, 即如上, 应返回索引0.我们应该对算法做出怎样的变化呢?

public static int BinarySearch_3(int[] arr, int target) {int i = 0;int j = arr.length - 1;//设置候选索引int cadicate = -1;int mid = i + (j - i) / 2;while (i <= j) {mid = i + (j - i) / 2;if (arr[mid] > target) {j = mid - 1;} else if (arr[mid] < target) {i = mid + 1;} else {//如果arr[mid] == target, 并不退出循环, 而是更新候选值, 继续向左排查cadicate = mid;j = mid - 1;}}return cadicate == -1 ? -1 : cadicate;}

test : 

@Testpublic void test1() {int[] arr = {1, 4, 7, 7, 7, 7,  8, 10};int target = 7;int index3 = BinarySearch_3(arr, target);System.out.println("索引处是" + index3);}控制台 : 
索引处是2

上述代码完成了返回了最左边的元素的索引, 如果我们想要得到最右边的元素的索引, 应该怎么办呢?非常简单, 只需要在else语句处略微改动.

else {//如果arr[mid] == target, 并不退出循环, 而是更新候选值, 继续向右排查cadicate = mid;i = mid + 1;
}

test : 

@Testpublic void test1() {int[] arr = {1, 4, 7, 7, 7, 7, 7, 8, 10};int target = 7;int index4 = BinarySearch_4(arr, target);System.out.println("索引处是" + index4);}控制台 : 
索引处是6

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSS特效---环形进度条

1、演示 2、一切尽在代码中 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content"w…

炉管设备的内部构造详解

知识星球&#xff08;星球名&#xff1a;芯片制造与封测社区&#xff09;里的学员问&#xff1a;炉管设备&#xff08;立式&#xff09;的内部构造是怎样的&#xff1f; 如上图&#xff0c;是一个典型的&#xff1a; 上半部&#xff1a; Heating Element&#xff08;加热线圈…

树莓派使用总结

手上拿到了一块Raspberry Pi 4B板子。研究一下怎么用。 安装系统 直接到官网【Raspberry Pi 】下载在线安装助手 安装好后&#xff0c;打开软件&#xff0c;选择好板子型号、系统、TF卡&#xff0c;一路下一步就行。 树莓派接口 直接查看官方的资料【Raspberry Pi hardwar…

yolov8下的训练指标解析

目录 一:训练指标 二:训练结果 一:训练指标 model = YOLO(yolov8n.pt) results = model.train(data="lvluo/lvluo.yaml", epochs=50) 这里的model.train中的参数data,epochs都是训练模型的相关参数,下面我们讲解下常用的参数指标。 1:data: 数据文件路…

实用电路图轻松掌握,一通百通 | 百能云芯

通过以下各种各样的实用电路&#xff0c;大家可以了解元器件的结构、特性、动作原理及电路的基本控制方式&#xff0c;掌握一些控制规律&#xff0c;这样的话&#xff0c;在日后的电路识图中就能融会贯通&#xff0c;一通百通。 文章中的电路图有难有易&#xff0c;有些图现在…

js将后端返回的blob请求下载

首先在请求里加上responseType: blob http({url: ,method: post,headers: {Content-Type: application/json},responseType: blob,data: saveObj })然后再返参里下载 http({url: ,method: post,headers: {Content-Type: application/json},responseType: blob,data: saveObj}…

贪吃蛇项目实战——学习详解

前言:贪吃蛇是一个经典的游戏&#xff0c; 本节将使用c语言实现一个简易的的贪吃蛇小游戏。 本节内容适合已经学完c语言还有数据结构链表的友友们。 我们要实现的贪吃蛇是在控制台进行游戏的。 它运行起来是这样的&#xff1a; 贪吃蛇 那么&#xff0c; 为了实现这个小游戏。 我…

YOLO8实战:行人跌倒检测系统

yolo8行人跌倒检测系统 前言 随着科技的不断进步&#xff0c;人工智能和深度学习技术已广泛应用于各行各业&#xff0c;尤其是在人身安全检测方面。传统的跌倒检测方法依赖于人工观察&#xff0c;但这种方法不仅耗时耗力&#xff0c;而且容易因人为因素导致误判或漏判。因此&a…

叉车4G无线视频监控管理解决方案:提升效率,保障安全

在现代物流行业中&#xff0c;叉车被广泛应用于仓储和物流领域&#xff0c;成为提升效率和降低成本的重要工具。然而&#xff0c;叉车作为重要的运输设备&#xff0c;其安全性和管理效率也备受关注。针对这一问题&#xff0c;叉车4G无线视频监控管理解决方案应运而生。 叉车是仓…

C++从零开始websevere服务器从搭建到上线|使用华为云服务器进行项目部署

文章目录 公网IP和私有IP地址公网IP私有IP地址为什么我们需要两个IP地址呢 云服务器设置防火墙配置基础配置云服务器防火墙配置云服务器安全组 总结 问题背景 关于使用华为云服务器进行项目部署&#xff0c;25届C秋招选手&#xff0c;刚写完一个websever项目&#xff0c;想着部…

Thinkphp命令行创建repository和transform层扩展包

前言 由于官方推荐的MVC架构在项目功能比较多的时候会导致controller层非常臃肿&#xff0c;不容易将代码复用&#xff0c;难以维护。所以现在很多程序员都喜欢将controller层拆分为controller、service、repository、model这几层甚至更多层次的目录进行开发&#xff0c;更容易…

【免费题库】华为OD机试 - 查找接口成功率最优时间段(Java JS Python C C++)

须知 哈喽,本题库完全免费,收费是为了防止被爬,大家订阅专栏后可以私信联系退款。感谢支持 文章目录 须知题目描述输入描述输出描述用例解题思路:Java代码:JS代码:Python代码:C代码:C++代码:题目描述 服务之间交换的接口成功率作为服务调用关键质量特性,某个时间段…

重温javascript --(二)函数

函数 一、定义 声明式 functon fn(){}表达式var fn function(){}(函数表达式一般指 匿名函数) 二、参数&#xff08;形参&#xff0c;实参&#xff09; arguments 类数组对象 表示函数的实参集合 arguments.callee—指向当前执行的函数 arguments.length—指向传递给当前函…

TypeScript学习笔记7-枚举

在 TypeScript 中&#xff0c;枚举&#xff08;Enum&#xff09;是一种数据类型&#xff0c;用于定义一组具名的常量值。 枚举可以帮助开发人员在代码中使用可读性更强的符号来表示固定的数值或状态。 枚举的定义类似于对象字面量&#xff0c;其中包含一组键值对&#xff0c;键…

工厂方法模式设计实验

【实验内容】 楚锋软件公司欲开发一个系统运行日志记录器&#xff08;Logger&#xff09;。该记录器可以通过多种途径保存系统的运行日志&#xff1a;例如通过文件记录或数据库记录&#xff0c;用户可以通过修改配置文件灵活地更换日志记录方式。在设计各类日志记录器时&#…

【智能算法】回溯搜索算法(BSA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2013年&#xff0c;P Civicioglu等人受到当前种群与历史种群之间的差分向量的引导启发&#xff0c;提出了回溯搜索算法&#xff08;Backtracking Search Algorithm, BSA&#xff09;。 2.算法原理…

刷题训练之二分查找

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;熟练掌握二分查找算法 > 毒鸡汤&#xff1a;学习&#xff0c;学习&#xff0c;再学习 ! 学&#xff0c;然后知不足。 > 专栏选自&#xff1a;刷题…

分析 MyBatis/MyBatis-Plus 慢 SQL 的分析组件 --SQL 慢镜️‍♀️

大家好&#xff01;我是聪ζ&#x1f331;我做了一个分析 MyBatis/MyBatis-Plus 慢 SQL 的分析组件 --SQL 慢镜&#x1f575;️‍♀️ GitHub仓库地址&#x1f680;: https://github.com/lhccong/sql-slow-mirror 点点 star 我的朋友们✨ 背景&#x1f9ca;&#xff1a; 大家…

(十五)C++自制植物大战僵尸游戏僵尸基类讲解

植物大战僵尸游戏开发教程专栏地址http://t.csdnimg.cn/m0EtD 在游戏中,最重要的两个类别就是植物与僵尸。僵尸可以对植物进行攻击,不同的僵尸攻击方式可能会不同,但是不同又有许多相同的属性。在基类(父类)中定义僵尸共有属性,供派生类(子类)继承。 僵尸状态转换 僵尸…

【漏洞复现】润乾报表 servlet/dataSphereServlet 任意文件上传漏洞

0x01 产品简介 润乾报表是一个纯JAVA的企业级报表工具,润乾报表作为领先的企业级报表分析软件,提供了高效的报表设计方案、强大的报表展现能力、灵活的部署机制,以及支持强关联语义模型。这些功能使得润乾报表能够为企业级数据分析与商业智能提供高性能、高效率的报表系统解…