二分查找以及變形

這個東西研究了好長時間,做下記錄。
二分查找的整體結(jié)構(gòu)如下:

while(lo ? hi){
  mid = (lo + hi)/2;
  if(key ? arr[mid])
     //......
  else
    //...... 
}

這片文章總結(jié)的挺好的,但是我又在解決其他問題的時候遇到不一樣的套路,比如這個。主要糾結(jié)就在于第一個問號。
經(jīng)過實驗發(fā)現(xiàn),一般我們的搜索都是在完全閉區(qū)間中進行搜索的,在這種情況下,第一個問號那里,必須寫<=。但如果寫成lo < hi - 1這種形式,意味著這是半開區(qū)間,在這個循環(huán)中不會找到hi這個右邊界。而在之前的那種情況下是可以找到右邊界的。代碼如下:

情況1:lo <= hi后面的lo和hi必須要mid加一或者減一的,返回的索引是mid。完整閉區(qū)間。
情況2:lo < hi-1后面的lo和hi必須等于mid,并且返回的索引是lo。去掉了右邊界。

情況1的常規(guī)代碼:

while(lo <= hi){
  mid = (lo + hi)/2;
  if(x < arr[mid]) hi = mid -1 ;
  else if(x > arr[mid]) lo = mid + 1;
  else return true;
}
return false;

情況2的常規(guī)代碼:

while(lo < hi-1){
  mid = (lo + hi)/2;
  if(x < arr[mid]) hi = mid;
  else lo = mid;
}
return arr[lo] == x;

在這個基礎(chǔ)上,我還想了如果寫了lo < hi這個條件,會出現(xiàn)什么情況。其實這個,經(jīng)過實驗,也是完全可以查找的,并且是完全閉區(qū)間的,但是需要多填一句代碼。因為前面第一種情況已經(jīng)實現(xiàn)了,所以沒有必要研究這個,盡管使用上面的兩種代碼。


二分查找,看似簡單,但還是很難寫對。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • 1 二分查找jdk源碼 時間O(logn)空間O(1) 遞歸式寫法: 時間和空間都是O(logn) 2. 二分插入...
    少冰三hun甜閱讀 476評論 0 1
  • 原理并不復雜,[low,high]構(gòu)成了潛在區(qū)間,如果中值不等于目標,則減半對應的區(qū)間。有一個問題:為什么循環(huán)條件...
    熊白白閱讀 818評論 0 0
  • 最近在讀< >時,了解到了很多常用的排序算法,故寫一篇讀書筆記記錄下這些排序算法的思路和實現(xiàn). 冒泡排序 冒泡排序...
    SylvanasSun閱讀 829評論 0 0
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,355評論 25 708
  • 朝發(fā)臨安郡兮,夕宿東陽。 茍余心糸兄弟情兮,雖路遠之何傷。 懷信躑躅,忽乎吾將行兮!
    鷺島燈泡王閱讀 233評論 0 0

友情鏈接更多精彩內(nèi)容