二分查找法
function binarySearch($arr, $val, $hight, $low = 0) {
$i = 0;
while ($low <= $hight) {
$i++;
$mid = ceil($low + ($hight - $low) / 2);
if ($arr[$mid] == $val) {
echo $i . PHP_EOL;
return $mid;
} elseif ($arr[$mid] > $val) {
$hight = $mid - 1;
} else {
$low = $mid + 1;
}
}
return - 1;
}
调用函数
$arr = range(20, 40);
$low = 0;
$hight = count($arr) - 1;
$findVal = rand(10, 50);
echo $findVal . PHP_EOL;
$result = binarySearch($arr, $findVal, $hight, $low);
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术