成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Java二分查找算法實現(xiàn)代碼實例-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設、高性價比銀川網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式銀川網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設找我們,業(yè)務覆蓋銀川地區(qū)。費用合理售后完善,10年實體公司更值得信賴。

二分查找:

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

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

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

代碼如下

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 初始左側指針 指向第一個元素
  // high 初始末尾指針 指向最后一個元素
  public static int binarySearch(int[] arr, int num, int low, int high) {
    
    int mid = (low + high) / 2; 
    
    // 遞歸結束條件
    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);
    
  }
  
}

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站jinyejixie.com,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

本文名稱:Java二分查找算法實現(xiàn)代碼實例-創(chuàng)新互聯(lián)
新聞來源:http://jinyejixie.com/article28/coehjp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設、面包屑導航關鍵詞優(yōu)化、響應式網(wǎng)站、網(wǎng)站維護、手機網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營
大同县| 屏东县| 金乡县| 厦门市| 仁布县| 揭东县| 赣榆县| 靖边县| 抚松县| 恩平市| 易门县| 彰化市| 德格县| 岗巴县| 旺苍县| 封丘县| 封丘县| 嘉荫县| 高雄县| 通山县| 井陉县| 达孜县| 铁岭县| 左云县| 石狮市| 伊宁县| 靖江市| 乐都县| 沧源| 肇庆市| 易门县| 江源县| 松阳县| 澄城县| 汪清县| 芦山县| 苗栗县| 历史| 镇康县| 韩城市| 兴义市|