ldq777888 2017-10-01 17:17 采纳率: 50%
浏览 863
已结题

各位大神,为什么二分法查找50的时候,会返回null?

function erfenfa($a,$value,$star,$end)
{

    if ( $star > $end ) 
    {
        return "数据 $value 不在范围内";
    }

    echo "开始从 $star - $end 之间寻找 <br>";
    $middle = floor( ($star+$end)/2 );
    $middle_value = $a[$middle];

    if ( $value == $middle_value ) 
    {
        return true;
    }

    elseif ( $value > $middle_value ) //从左边找
    {
        $end = $middle-1;
        erfenfa($a,$value,$star,$end);
    }

    elseif ( $value < $middle_value ) //从右边找
    {
        $star = $middle+1;
        erfenfa($a,$value,$star,$end);
    }
}

$length = count($a);
$star = 0;
$end = $length-1;
$value = 50;

echo "用二分法查找 $value <br>";
$s = erfenfa($a,$value,$star,$end);
var_dump($s);
  • 写回答

6条回答 默认 最新

  • threenewbee 2017-10-02 00:52
    关注

    二分法要求数据本身是有序的,你的输入是否满足这个前提。

    评论

报告相同问题?

悬赏问题

  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置