真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java中如何實(shí)現(xiàn)一個(gè)二分查找算法-創(chuàng)新互聯(lián)

本篇文章給大家分享的是有關(guān)Java中如何實(shí)現(xiàn)一個(gè)二分查找算法,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括利辛網(wǎng)站建設(shè)、利辛網(wǎng)站制作、利辛網(wǎng)頁制作以及利辛網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,利辛網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到利辛省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

二分查找:

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

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

注意事項(xiàng):排序規(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è)指針 指向第一個(gè)元素  // high 初始末尾指針 指向最后一個(gè)元素  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);      }  }

以上就是Java中如何實(shí)現(xiàn)一個(gè)二分查找算法,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


當(dāng)前名稱:Java中如何實(shí)現(xiàn)一個(gè)二分查找算法-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://weahome.cn/article/ceegjj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部