Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解
Java二分查找
使用前提:二分查找需要在有序數(shù)組中進(jìn)行查找
需求
請(qǐng)對(duì)一個(gè)有序數(shù)組進(jìn)行二分查找{1,8,10,89,1000,1024},輸入一個(gè)數(shù)字看看該數(shù)組中是否存在此數(shù),并且求出下標(biāo),如果沒有就返回“-1”
思路分析:
首先確定該數(shù)組的中間下標(biāo)
1.mid=(left+right)/2
2.然后讓需要查找的數(shù)findval和arr[mid]比較
- findval>arr[mid]說明你要查找的數(shù)字在mid的右邊,因此需要遞歸的向右進(jìn)行查找
- findval<arr[mid]說明你要查找的數(shù)字咋mid的左邊,因此需要遞歸的向左進(jìn)行查找
- findval==arr[mid]說明找到,就返回
什么時(shí)候需要結(jié)束遞歸?
1.找到了數(shù)據(jù)就結(jié)束遞歸
2.遞歸完整個(gè)數(shù)組,仍然沒有找到findval,也需要結(jié)束遞歸 當(dāng)left>right就需要退出
代碼實(shí)現(xiàn)
/** * 二分查找 * 使用二分查找的前提 數(shù)組必須有序 從小到大 從大到小都可以 * * @create: 2021/10/2 * @author: Tony Stark */ public class BinarySearch { public static void main(String[] args) { int[] arr = {1, 8, 10, 89, 1000, 1024}; int i = binarySearch(arr, 0, arr.length - 1, 1024); System.out.println(i); } /** * 二分查找的方法 * @param arr 數(shù)組 * @param left 左邊的索引 * @param right 右邊的索引 * @param findVal 要查找的值 * @return 如果找到就返回下標(biāo) ,沒有找到就返回-1 */ public static int binarySearch(int[] arr,int left,int right,int findVal){ //當(dāng)left大于right時(shí)說明遞歸了整個(gè)數(shù)組但是沒有找到 if (left>right){ return -1; } //中間值的下標(biāo) int mid=(left+right)/2; //中間值 int midVal=arr[mid]; //如果要找的值大于中間值 向右遞歸 現(xiàn)在數(shù)組是從小到大 所以向右遞歸 if (findVal>midVal){ //向右遞歸 return binarySearch(arr,mid+1,right,findVal); }else if(findVal<midVal){ //如果要找的值小于中間值向左遞歸 return binarySearch(arr, left,mid-1, findVal); }else if (findVal==midVal){ //這種情況就是找到了那個(gè)數(shù)字 return mid; } return -1; } }
輸出
5
到此這篇關(guān)于Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解的文章就介紹到這了,更多相關(guān)Java二分查找內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實(shí)現(xiàn)方法和原理詳解
- Java數(shù)據(jù)結(jié)構(gòu)中七種排序算法實(shí)現(xiàn)詳解
- Java數(shù)據(jù)結(jié)構(gòu)中關(guān)于AVL樹的實(shí)現(xiàn)方法詳解
- Java數(shù)據(jù)結(jié)構(gòu)和算法之鏈表詳解
- Java數(shù)據(jù)結(jié)構(gòu)篇之實(shí)現(xiàn)二叉搜索樹的核心方法
- Java數(shù)據(jù)結(jié)構(gòu)中的HashMap和HashSet詳解
- Java常見的數(shù)據(jù)結(jié)構(gòu)之棧和隊(duì)列詳解
- java手動(dòng)實(shí)現(xiàn)常見數(shù)據(jù)結(jié)構(gòu)的示例代碼
相關(guān)文章
Java rmi遠(yuǎn)程方法調(diào)用基本用法解析
這篇文章主要介紹了Java rmi遠(yuǎn)程方法調(diào)用基本用法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05Java批量操作文件系統(tǒng)的實(shí)現(xiàn)示例
文件上傳和下載是java web中常見的操作,本文主要介紹了Java批量操作文件系統(tǒng)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-03-03SpringBoot中5種動(dòng)態(tài)代理的實(shí)現(xiàn)方案
在SpringBoot應(yīng)用中,動(dòng)態(tài)代理被廣泛用于實(shí)現(xiàn)事務(wù)管理、緩存、安全控制、日志記錄等橫切關(guān)注點(diǎn),下面小編為大家介紹一下SpringBoot中5種動(dòng)態(tài)代理的實(shí)現(xiàn)方案吧2025-04-04Spring Security實(shí)現(xiàn)身份認(rèn)證和授權(quán)的示例代碼
在 Spring Boot 應(yīng)用中使用 Spring Security 可以非常方便地實(shí)現(xiàn)用戶身份認(rèn)證和授權(quán),本文主要介紹了Spring Security實(shí)現(xiàn)身份認(rèn)證和授權(quán)的示例代碼,感興趣的可以了解一下2023-06-06Spring boot中PropertySource注解的使用方法詳解
這篇文章主要給大家介紹了關(guān)于Spring boot中PropertySource注解的使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12使用nexus3.X上傳本地jar包并且通過pom讀取的解決方案(全網(wǎng)最新)
這篇文章主要介紹了使用nexus3.X上傳本地jar包并且通過pom讀取的解決方案(全網(wǎng)最新),本文內(nèi)容有點(diǎn)長(zhǎng),結(jié)合圖文實(shí)例給大家講解的非常詳細(xì),需要的朋友可以參考下2023-11-11微信企業(yè)號(hào)驗(yàn)證/發(fā)送/接收消息
這篇文章主要介紹了微信企業(yè)號(hào)驗(yàn)證/發(fā)送/接收消息的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-10-10