insgo 2020-07-10 11:31 采纳率: 50%
浏览 101
已采纳

php 2分查找, return true结果var_dump()是null

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));
  • 写回答

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 这个是哪里有问题啊?