欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解

 更新時(shí)間:2023年12月18日 09:34:54   作者:暴躁的程序猿啊  
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解,二分查找算法是一種在有序數(shù)組中查找某一特定元素的搜索算法,其思想就是不斷地將有序查找表“一分為二”,逐漸縮小搜索區(qū)域,進(jìn)而找到目標(biāo)元素,需要的朋友可以參考下

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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談Apache Maven ToolChains的使用

    淺談Apache Maven ToolChains的使用

    Maven是java中非常有用和常用的構(gòu)建工具,基本上現(xiàn)在大型的java項(xiàng)目都是Maven和gradle的天下了。本文將介紹Apache Maven ToolChains的使用。
    2021-06-06
  • Java rmi遠(yuǎn)程方法調(diào)用基本用法解析

    Java rmi遠(yuǎn)程方法調(diào)用基本用法解析

    這篇文章主要介紹了Java rmi遠(yuǎn)程方法調(diào)用基本用法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Java批量操作文件系統(tǒng)的實(shí)現(xiàn)示例

    Java批量操作文件系統(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-03
  • SpringBoot中5種動(dòng)態(tài)代理的實(shí)現(xiàn)方案

    SpringBoot中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-04
  • Spring Security實(shí)現(xiàn)身份認(rèn)證和授權(quán)的示例代碼

    Spring 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-06
  • Java判斷字節(jié)流是否是 UTF8編碼方法示例

    Java判斷字節(jié)流是否是 UTF8編碼方法示例

    這篇文章主要我大家介紹了Java判斷字節(jié)流是否是 UTF8編碼方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Spring boot中PropertySource注解的使用方法詳解

    Spring boot中PropertySource注解的使用方法詳解

    這篇文章主要給大家介紹了關(guān)于Spring boot中PropertySource注解的使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • SpringBoot中的Aop用法示例詳解

    SpringBoot中的Aop用法示例詳解

    這篇文章主要介紹了SpringBoot中的Aop用法,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • 使用nexus3.X上傳本地jar包并且通過pom讀取的解決方案(全網(wǎng)最新)

    使用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ā)送/接收消息

    這篇文章主要介紹了微信企業(yè)號(hào)驗(yàn)證/發(fā)送/接收消息的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-10-10

最新評(píng)論