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 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办