21,887
社区成员
发帖
与我相关
我的任务
分享
function BinarySearch ($arr, $searchVal, $leftIndex, $rightIndex) {
if ($rightIndex < $leftIndex) {
return 'ERROR';
}
$midIndex = round(($leftIndex + $rightIndex) / 2);
$midVal = $arr[$midIndex];
if ($searchVal < $midVal) {
return BinarySearch($arr, $searchVal, $leftIndex, $midIndex - 1); //这里需要返回
} else if ($searchVal > $midVal) {
return BinarySearch($arr, $searchVal, $midIndex + 1, $rightIndex); //这里也需要返回
} else {
return $midIndex;
}
}