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 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 qgcomp混合物线性模型分析的代码出现错误:Model aliasing occurred
  • ¥100 已有python代码,要求做成可执行程序,程序设计内容不多
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥15 小红薯封设备能解决的来
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助
  • ¥15 STM32控制MAX7219问题求解答