>백엔드 개발 >PHP 튜토리얼 >PHP는 절반 쿼리 알고리즘을 구현합니다.

PHP는 절반 쿼리 알고리즘을 구현합니다.

WBOY
WBOY원래의
2016-07-29 08:55:28847검색

PHP는 절반 쿼리 알고리즘을 구현하며 표준화되지 않은 코드를 직접 작성합니다.

반쿼리 알고리즘이란? 구체적인 단어로 Baidu에 자신을 설명하십시오. 코드 직접 업로드:

<?php
header("Content-type: text/html; charset=utf-8"); 

/* 折半查询算法--不用递归 */
function qSort($data = array(), $x = 0){
	$startIndex = 0;                // 开始索引
	$endIndex = count($data) - 1;   // 结束索引
	$index = 0;
	$number = 0;                    // 计数器
	do{
		if($endIndex > $startIndex){
			$searchIndex = ceil(($endIndex - $startIndex) / 2);
		}else if($endIndex == $startIndex){
			$searchIndex = $endIndex;
		}else{
			$index = -1;
			break;
		}
		$searchIndex += ($startIndex - 1);

		echo '检索范围:'.$startIndex.' ~ '.$endIndex.'<br>检索位置:'.$searchIndex.'检索值为:'.$data[$searchIndex];
		echo '<br>=======================<br><br>';

		if($data[$searchIndex] == $x){
			$index = $searchIndex;
			break;
		}else if($x > $data[$searchIndex]){
			$startIndex = $searchIndex + 1;
		}else{
			$endIndex = $searchIndex - 1;
		}

		$number++;
	}while($number < count($data));
	return $index;
}

/* 折半查询算法--使用递归 */
function sSort($data, $x, $startIndex, $endIndex){
	if($endIndex > $startIndex){
		$searchIndex = ceil(($endIndex - $startIndex) / 2);
	}else if($endIndex == $startIndex){
		$searchIndex = $endIndex;
	}else{
		return -1;
	}

	$searchIndex += ($startIndex - 1);

	echo '检索范围:'.$startIndex.' ~ '.$endIndex.'<br>检索位置:'.$searchIndex.'检索值为:'.$data[$searchIndex];
	echo '<br>=======================<br><br>';

	if($data[$searchIndex] == $x){
		return $searchIndex;
	}else if($x > $data[$searchIndex]){
		$startIndex = $searchIndex + 1;
		return sSort($data, $x, $startIndex, $endIndex);
	}else{
		$endIndex = $searchIndex - 1;
		return sSort($data, $x, $startIndex, $endIndex);
	}
}

$data = array(1, 3, 4, 6, 9, 11, 12, 13, 15, 20, 21, 25, 33, 34, 35, 39, 41, 44);

$index = qSort($data, 11);                       // 不用递归的排序方法
$index = sSort($data, 11, 0, count($data) - 1);  // 使用递归的排序方法
echo '结果:'.$index;

위 내용은 관련 측면을 포함하여 PHP에서 절반 쿼리 알고리즘의 구현을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.