Rumah > pembangunan bahagian belakang > tutorial php > PHP二分查找的困惑

PHP二分查找的困惑

WBOY
Lepaskan: 2016-06-13 12:15:10
asal
1058 orang telah melayarinya

PHP二分查找的疑惑
$Arr=array(1,3,4,5,7,8,9);
Search($Arr,7,0,count($Arr)-1);
function Search($Arr,$FindVal,$LeftIndex,$RightIndex){
if($FindVal>$Arr[count($Arr)-1]){
echo "找不到该值";
}else if($FindValecho "找不到该值";
}else{
$MiddleIndex=round(($LeftIndex+$RightIndex)/2);
if ($Arr[$MiddleIndex]Search($Arr,$FindVal,++$MiddleIndex,$RightIndex);
}else if($Arr[$MiddleIndex]>$FindVal){
Search($Arr,$FindVal,$LeftIndex,--$MiddleIndex);
}else{
echo "找到下标为$MiddleIndex";
}
}
}

请问下各位朋友,这段代码执行下来,是不是执行了好几个函数。有朋友能深入讲解下时序图吗? 谢谢,感激不尽。
------解决思路----------------------

$Arr = array(1,3,4,5,7,8,9);<br />Search($Arr,7,0,count($Arr)-1);<br /><br />function Search($Arr,$FindVal,$LeftIndex,$RightIndex){<br />  echo "$FindVal,$LeftIndex,$RightIndex\n"; //加上这句<br />  if($FindVal>$Arr[count($Arr)-1]){<br />    echo "找不到该值";<br />  }else if($FindVal<$Arr[0]){<br />    echo "找不到该值";<br />  }else{<br />    $MiddleIndex=round(($LeftIndex+$RightIndex)/2);<br />    if ($Arr[$MiddleIndex]<$FindVal){<br />      Search($Arr,$FindVal,++$MiddleIndex,$RightIndex);<br />    }else if($Arr[$MiddleIndex]>$FindVal){<br />      Search($Arr,$FindVal,$LeftIndex,--$MiddleIndex);<br />    }else{<br />      echo "找到下标为$MiddleIndex";<br />    }<br />  }<br />}
Salin selepas log masuk
7,0,6
7,4,6
7,4,4
找到下标为4

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan