function searchNum($arr,$num,$start=0,$end=null){
if($start>$end){
return false;
}
$count=count($arr);
if(!$end){
$end=$count-1;
}
$mid=floor(($start+$end)/2);
echo $num,'<br>';
echo $mid,' : ',$arr[$mid],' ';
if($arr[$mid]==$num){
echo true;
return true;
}
elseif($arr[$mid]>$num){
searchNum($arr,$num,$start,$mid-1);
}
else{
searchNum($arr,$num,$mid+1,$end);
}
}
$arr1=[1,2,3,15,18,21,23,34,38,42,45,48,68,77,79,81,84,88,91,99,102,105,110];
var_dump(searchNum($arr1,45));
php 2分查找, return true结果var_dump()是null
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- Tournesol1530215484 2020-07-13 16:15关注
<?php function searchNum($arr,$num,$start=0,$end=null){ if($start>$end){ return false; } $count=count($arr); if(!$end){ $end=$count-1; } $mid=floor(($start+$end)/2); if($arr[$mid]==$num){ return true; } elseif($arr[$mid]>$num){ return searchNum($arr,$num,$start,$mid-1); } else{ return searchNum($arr,$num,$mid+1,$end); } } $arr1=[1,2,3,15,18,21,23,34,38,42,45,48,68,77,79,81,84,88,91,99,102,105,110]; $res=searchNum($arr1,45); var_dump($res);
你的在
searchNum($arr,$num,$mid+1,$end);
这里加return 不然
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 乌班图ip地址配置及远程SSH
- ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
- ¥15 PSPICE制作一个加法器
- ¥15 javaweb项目无法正常跳转
- ¥15 VMBox虚拟机无法访问
- ¥15 skd显示找不到头文件
- ¥15 机器视觉中图片中长度与真实长度的关系
- ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
- ¥15 java 的protected权限 ,问题在注释里
- ¥15 这个是哪里有问题啊?