如何優(yōu)雅地寫二分搜索

二分搜索大家都會(huì),但是一般我們都是采用閉區(qū)間[a,b]的方式來(lái)進(jìn)行搜索,并且循環(huán)條件一般是left <= right。但是這種方式需要考慮的邊界條件比較多,這里推薦二分搜索最好采用半開區(qū)間[a,b)判斷的方式,也就是說(shuō)如果數(shù)組大小為n,那初始的left設(shè)為0,right設(shè)為n。以下代碼足夠簡(jiǎn)潔,并且可以返回第一個(gè)大于等于target的數(shù)的index:

private int binarySearch(int[] arr, int target) {
        int left = 0, right = arr.length;    // 注意這個(gè)初始right設(shè)為數(shù)組長(zhǎng)度
        while (left < right) {
            // 推薦采用這種方式取mid,而不是 mid = (left + right) / 2,因?yàn)楹笳呖赡軙?huì)導(dǎo)致溢出
            int mid = left + (right - left)/2; 
            if (arr[mid] < target)
                left = mid+1;
            else right = mid;
        }
        return left;  // 這里不需要考慮返回left還是right,因?yàn)樽罱Kleft總是等于right
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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