PHP 데이터 구조 (1) 이진 검색

WBOY
풀어 주다: 2016-08-08 09:32:52
원래의
982명이 탐색했습니다.

이진 검색의 기본 개념은 정렬된 배열의 중간 값과 검색 중인 값을 비교하는 것입니다. 검색되는 값이 배열의 중간 값보다 클 경우, 정렬된 배열의 중간값은 이전의 모든 값이 검색하려는 값보다 작기 때문에 배열의 중간값 이전의 모든 값을 제외하고 계속해서 중간값에서 필요한 값을 검색하면 됩니다. 코드는 다음과 같이 구현됩니다:

//이진 검색
function bin_search($array,$search ){
$low=0;
$height= count($array)-1;//배열 길이 가져오기

while($low<=$height){
$mid=floor(($low+$height)/2);//오류 방지를 위해 중간 숫자를 구해서 바닥형으로 강제 지정
if($array[$mid]==$search){
return $mid+1;//찾은 시퀀스 번호를 반환
}else if($array[$mid]<$search) {
//가운데 값이 체크된 값보다 작은 경우, $mid 왼쪽의 값은 모두 $search보다 작습니다. 이때 $mid는 $low
$low=$mid+1;<에 할당되어야 합니다. 🎜>
}else if($array[$mid]>$search){

//이때, 중간값이 더 크다는 뜻 확인된 값보다 $mid 오른쪽의 모든 값이 $search보다 크다면 $mid는 $height
$height에 할당되어야 합니다. $mid-1;
}
return "Search failed";//검색에 실패했습니다. 값이 배열에 없습니다

}

}
$arr= 배열(1,4,6,33,75,88,89,93);
echo bin_search($arr,33);
echo bin_search($ 도착, 66);?>

위의 내용은 PHP 데이터 구조 (1) 바이너리 검색에 대한 내용을 포함하여 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿