二分查找算法的兩種實現(xiàn)方式

一、二分查找法(二分折半查找)

1茶鹃、普通方法

/**
*@paramarr待查詢數(shù)組
*@paramfindValue待查詢值
*@return查詢值索引
*/

private static int binaryFind(int arr[], int findValue) {
       //最小索引
       int lowerBound = 0;
       //最大索引
       int upperBound = arr.length - 1;
       //中間索引
       int middleIndex;
       //思想:1侄泽、當最小索引小于等于最大索引時
       //      2懈贺、獲得middleIndex(中間索引)犀忱,以此判斷middleIndex對應(yīng)的值和findValue(查找值)是否對等
       //      3、如果對等拜银,則返回當前索引殊鞭,否則改變最小和最大索引
       //      4、不對等的情況尼桶,如果當前middleIndex對應(yīng)的值小于findValue操灿,則改變最小索引為middleIndex+1,否則改變最大索引為middleIndex-1
       //      5、以此循環(huán)泵督,最終得到findValue的索引
       while (lowerBound <= upperBound) {
           middleIndex = (lowerBound + upperBound) / 2;
           if (arr[middleIndex] == findValue) {
               return middleIndex;
           } else {
               if (arr[middleIndex] < findValue) {
                   lowerBound = middleIndex + 1;
               } else {
                   upperBound = middleIndex - 1;
               }
           }
       }
       return -1;
   }  

2牲尺、遞歸方法

 /**
 * 二分查找遞歸算法
 * @param arr 待查詢數(shù)組
 * @param currentValue 待查詢值
 * @param beginIndex 起始索引
 * @param endIndex 結(jié)束索引
 * @return 查詢值索引
 */
private static int recursionBinaryFind(int[] arr, int currentValue, int beginIndex, int endIndex) {
    if (beginIndex <= endIndex) {
        int middleIndex = (beginIndex + endIndex) / 2;
        //當查找值等于中間值時
        if (currentValue == arr[middleIndex]) {
            return middleIndex;
            //當查找值大于中間值時,改變起始索引和結(jié)束索引,開始遞歸
        } else if (arr[middleIndex] < currentValue) {
            return recursionBinaryFind(arr, currentValue, middleIndex + 1, endIndex);
            //當查找值小于中間值時谤碳,改變起始索引和結(jié)束索引,開始遞歸
        } else{
            return recursionBinaryFind(arr, currentValue, beginIndex, middleIndex - 1);
        }
    } else {
        return -1;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末溢豆,一起剝皮案震驚了整個濱河市蜒简,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌漩仙,老刑警劉巖搓茬,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異队他,居然都是意外死亡卷仑,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門麸折,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锡凝,“玉大人,你說我怎么就攤上這事垢啼〈芫猓” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵芭析,是天一觀的道長锚扎。 經(jīng)常有香客問我,道長馁启,這世上最難降的妖魔是什么驾孔? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮惯疙,結(jié)果婚禮上翠勉,老公的妹妹穿的比我還像新娘。我一直安慰自己螟碎,他們只是感情好眉菱,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著掉分,像睡著了一般俭缓。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上酥郭,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天华坦,我揣著相機與錄音,去河邊找鬼不从。 笑死惜姐,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播歹袁,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼坷衍,長吁一口氣:“原來是場噩夢啊……” “哼条舔!你這毒婦竟也來了枫耳?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤迁杨,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后凄硼,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體铅协,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡摊沉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了坯钦。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片预皇。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖婉刀,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情突颊,我是刑警寧澤鲁豪,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站律秃,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏棒动。R本人自食惡果不足惜糙申,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望船惨。 院中可真熱鬧,春花似錦粱锐、人聲如沸疙挺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春搀暑,著一層夾襖步出監(jiān)牢的瞬間沥阳,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工险掀, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人樟氢。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓,卻偏偏與公主長得像侠鳄,于是被迫代替她去往敵國和親埠啃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內(nèi)容