The ceiling ε=ε=ε=(~ ̄▽ ̄)~

PHP实现二分法查找

二分查找法需要数组是一个有序的数组。

<?php
function binarySearch($num, $arr) {
	$start = 0;
	$end = count($arr);
	$mid = floor(($start+$end)/2);

	while ($start<$end-1) {
		if ($num == $arr[$mid]) {
			return $mid;
		} elseif ($num < $arr[$mid]) {
			$end = $mid;
			$mid = floor(($start+$end)/2);
		} else {
			$start = $mid;
			$mid = floor(($start+$end)/2);
		}
	}
	return false;
}
$arr = [1,2,3,4,5,6,7,8,9,10];
$result = binarySearch(7,$arr);
print_r($result);
posted @ 2018-10-29 11:19  ImClive  阅读(358)  评论(0编辑  收藏  举报