我的代码出了什么问题 - 循环排序数组不显示任何结果
我今天接受了面试,那个人问我这个问题:
如何在循环排序数组中轻松查找项目
由于我不知道答案,我试图找到一个解决方案。以下是我所拥有的:
谢谢
<?php
function searchincircularsorterlist($a, $len, $num) {
$start=0;
$end=$len-1;
$mid = 0;
while($start<$end) {
$mid=$start+$end/2;
if ($num == $a[$mid]) {
return $num;
}
if($num<$a[$mid]) {
if($num<$a[$start] && $a[$start]<=$a[$start+1])
$start=$mid++;
else
$end=$mid--;
}
else {
if($num>$a[$end] && $a[$end-1]<=$a[end])
$end=$mid--;
else
$start=$mid++;
}
}
if ($start == $end && $num == $a[$start]) {
return $num;
}
return -1;
}
$array = array(7,8,9,0,1,2,3,4,5,6);
var_dump(searchincircularsorterlist($array,sizeof($array),4));
我正在尝试使用循环排序的数组,但由于某种原因它不起作用。我的代码出了什么问题?