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

Java二分查找算法實現(xiàn)代碼實例

 更新時間:2019年11月05日 09:25:13   作者:hejjon  
這篇文章主要介紹了Java二分查找算法實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

這篇文章主要介紹了Java二分查找算法實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

二分查找:

兩種方式: 非遞歸方式和遞歸方式

主要思路: 對于已排序的數(shù)組(先假定是從小到大排序), 先定義兩個"指針", 一個"指向"首元素low, 一個"指向"末尾元素high. 然后, 開始折半比較, 即讓要查找的數(shù)與數(shù)組中間的元素(索引為 low+high/2)比較. 若要查找的數(shù)比中間數(shù)小, 說明要查找的數(shù)在數(shù)組左側(cè)(注意前提是數(shù)組從小到大排序), 否則說明該數(shù)在數(shù)組的右側(cè). 如果low最后還比high大,倆"指針"交叉了, 說明沒有找到該數(shù), 即數(shù)組不存在該數(shù).

注意事項: 排序規(guī)則與數(shù)組的排序順序有關(guān), 即從大到小排序和從小到大排序是不一樣的!!!

代碼如下

class BinarySearch {
  
  // 二分查找非遞歸方式
  // arr 給定已排序數(shù)組
  // num 要查找的數(shù)
  public static int search(int[] arr, int num) {
    int low = 0;
    int high = arr.length - 1;
    int mid = 0;
    while (low <= high) {
      mid = (low + high) / 2;
      if (num < arr[mid]) {
        high = mid - 1;
      }
      
      if (num > arr[mid]) {
        low = mid + 1;
      }
      if (num == arr[mid]) {
        return mid;
      }
    }
    return -1;  // 沒找到
  }
  
  
  // 二分查找遞歸方式
  // arr 給定已排序數(shù)組
  // num 要查找的數(shù)
  // low 初始左側(cè)指針 指向第一個元素
  // high 初始末尾指針 指向最后一個元素
  public static int binarySearch(int[] arr, int num, int low, int high) {
    
    int mid = (low + high) / 2; 
    
    // 遞歸結(jié)束條件
    if (low > high) {
      return -1;
    }
    
    if (num < arr[mid]) {
      return binarySearch(arr, num, low, mid - 1);
    } else if (num == arr[mid]) {
      return mid;
    } else {
      return binarySearch(arr, num, mid + 1, high);
    }
    
  }
  
  
  public static void main(String[] args) {
    
    // 給定數(shù)組 從小到大排序.
    int[] arr = {2, 3, 5, 7, 8, 9, 11, 12, 15};
    // int[] arr = {15, 12, 11, 9, 8, 7, 5, 3, 2};
    
    int m = 3;
    
    // int index = search(arr, m);
    
    int index = binarySearch(arr, m, 0, arr.length - 1);
    
    System.out.println(index);
    
  }
  
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Elasticsearch學(xué)習(xí)之Terms?set?查詢

    Elasticsearch學(xué)習(xí)之Terms?set?查詢

    這篇文章主要為大家介紹了Elasticsearch學(xué)習(xí)Terms?set?查詢示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • SpringMVC @NotNull校驗不生效的解決方案

    SpringMVC @NotNull校驗不生效的解決方案

    這篇文章主要介紹了SpringMVC @NotNull校驗不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • SpringBoot2 集成log4j2日志框架的實現(xiàn)

    SpringBoot2 集成log4j2日志框架的實現(xiàn)

    這篇文章主要介紹了SpringBoot2 集成log4j2日志框架的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Java調(diào)用第三方http接口的常用方式總結(jié)

    Java調(diào)用第三方http接口的常用方式總結(jié)

    這篇文章主要介紹了Java調(diào)用第三方http接口的常用方式總結(jié),具有很好的參考價值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Java實現(xiàn)視頻初步壓縮和解壓的代碼示例

    Java實現(xiàn)視頻初步壓縮和解壓的代碼示例

    從攝像頭讀取每一幀的圖片,用一些簡單的方法將多張圖片信息壓縮到一份文件中(自定義的視頻文件),自定義解碼器讀取視頻文件,并將每幀圖片展示成視頻,本文主要介紹了Java實現(xiàn)視頻初步壓縮和解壓,需要的朋友可以參考下
    2023-10-10
  • 詳細(xì)介紹Java函數(shù)式接口

    詳細(xì)介紹Java函數(shù)式接口

    函數(shù)式接口在Java中是指有且僅有一個抽象方法的接口。當(dāng)然接口中可以包含其他的方法默認(rèn)、靜態(tài)、私有,具體內(nèi)容請參考下面文章內(nèi)容
    2021-09-09
  • 詳解MyBatisPlus邏輯刪除與唯一索引沖突問題

    詳解MyBatisPlus邏輯刪除與唯一索引沖突問題

    這篇文章主要介紹了詳解MyBatisPlus邏輯刪除與唯一索引沖突問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • SpringBoot整合Redis實現(xiàn)token緩存

    SpringBoot整合Redis實現(xiàn)token緩存

    于token通常會被多次使用,我們需要把它保存到緩存中,以減少頻繁地訪問數(shù)據(jù)庫,本文主要介紹了SpringBoot整合Redis實現(xiàn)token緩存,感興趣的可以了解一下
    2024-02-02
  • Intellij IDEA中如何查看maven項目中所有jar包的依賴關(guān)系圖

    Intellij IDEA中如何查看maven項目中所有jar包的依賴關(guān)系圖

    這篇文章主要介紹了Intellij IDEA中如何查看maven項目中所有jar包的依賴關(guān)系圖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Java中二維數(shù)組的正確使用方法介紹

    Java中二維數(shù)組的正確使用方法介紹

    Java中有一維數(shù)組,二維數(shù)組以及多維數(shù)組,在這篇文章中,將給大家詳細(xì)介紹一下如何正確使用Java中的二維數(shù)組,感興趣的小伙伴跟著小編一起學(xué)習(xí)吧
    2023-05-05

最新評論