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

Java數據結構與算法之二分查找詳解

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

Java二分查找

使用前提:二分查找需要在有序數組中進行查找

需求

請對一個有序數組進行二分查找{1,8,10,89,1000,1024},輸入一個數字看看該數組中是否存在此數,并且求出下標,如果沒有就返回“-1”

思路分析:

首先確定該數組的中間下標

1.mid=(left+right)/2

2.然后讓需要查找的數findval和arr[mid]比較

  • findval>arr[mid]說明你要查找的數字在mid的右邊,因此需要遞歸的向右進行查找
  • findval<arr[mid]說明你要查找的數字咋mid的左邊,因此需要遞歸的向左進行查找
  • findval==arr[mid]說明找到,就返回

什么時候需要結束遞歸?

1.找到了數據就結束遞歸

2.遞歸完整個數組,仍然沒有找到findval,也需要結束遞歸 當left>right就需要退出

代碼實現

/**
 * 二分查找
 * 使用二分查找的前提 數組必須有序  從小到大 從大到小都可以
 *
 * @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  數組
     * @param left   左邊的索引
     * @param right   右邊的索引
     * @param findVal  要查找的值
     * @return  如果找到就返回下標  ,沒有找到就返回-1
     */
    public static int binarySearch(int[] arr,int left,int right,int findVal){
        //當left大于right時說明遞歸了整個數組但是沒有找到
        if (left>right){
            return -1;
        }
        //中間值的下標
        int mid=(left+right)/2;
        //中間值
        int midVal=arr[mid];
        //如果要找的值大于中間值   向右遞歸  現在數組是從小到大  所以向右遞歸
        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){
            //這種情況就是找到了那個數字
            return mid;
        }
        return -1;
    }
}

輸出

5

到此這篇關于Java數據結構與算法之二分查找詳解的文章就介紹到這了,更多相關Java二分查找內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 淺談Apache Maven ToolChains的使用

    淺談Apache Maven ToolChains的使用

    Maven是java中非常有用和常用的構建工具,基本上現在大型的java項目都是Maven和gradle的天下了。本文將介紹Apache Maven ToolChains的使用。
    2021-06-06
  • Java rmi遠程方法調用基本用法解析

    Java rmi遠程方法調用基本用法解析

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

    Java批量操作文件系統(tǒng)的實現示例

    文件上傳和下載是java web中常見的操作,本文主要介紹了Java批量操作文件系統(tǒng)的實現示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-03-03
  • SpringBoot中5種動態(tài)代理的實現方案

    SpringBoot中5種動態(tài)代理的實現方案

    在SpringBoot應用中,動態(tài)代理被廣泛用于實現事務管理、緩存、安全控制、日志記錄等橫切關注點,下面小編為大家介紹一下SpringBoot中5種動態(tài)代理的實現方案吧
    2025-04-04
  • Spring Security實現身份認證和授權的示例代碼

    Spring Security實現身份認證和授權的示例代碼

    在 Spring Boot 應用中使用 Spring Security 可以非常方便地實現用戶身份認證和授權,本文主要介紹了Spring Security實現身份認證和授權的示例代碼,感興趣的可以了解一下
    2023-06-06
  • Java判斷字節(jié)流是否是 UTF8編碼方法示例

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

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

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

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

    SpringBoot中的Aop用法示例詳解

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

    使用nexus3.X上傳本地jar包并且通過pom讀取的解決方案(全網最新)

    這篇文章主要介紹了使用nexus3.X上傳本地jar包并且通過pom讀取的解決方案(全網最新),本文內容有點長,結合圖文實例給大家講解的非常詳細,需要的朋友可以參考下
    2023-11-11
  • 微信企業(yè)號驗證/發(fā)送/接收消息

    微信企業(yè)號驗證/發(fā)送/接收消息

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

最新評論