>  기사  >  백엔드 개발  >  PHP에서 이진 검색 알고리즘을 구현하는 방법

PHP에서 이진 검색 알고리즘을 구현하는 방법

黄舟
黄舟원래의
2017-09-14 09:40:542086검색

이 기사에서는 주로 PHP 이진 검색 알고리즘의 구현 방법을 소개하고 이진 검색 알고리즘의 원리를 간략하게 분석하며 구체적인 예를 결합하여 PHP가 루프 및 재귀 기반 이진 검색을 구현하는 데 필요한 관련 운영 기술을 제공합니다. 친구가 참조할 수 있습니다. 이 기사에

이 기사에서는 PHP 이진 검색 알고리즘의 구현 방법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

이진 검색 방법에서는 배열이 순서 있는 배열이어야 합니다.

우리 배열이 증가하는 배열이라고 가정하면 먼저 배열의 중간 위치를 찾아야 합니다.

1. 중간 위치를 알기 위해서는 시작 위치와 끝 위치를 알아야 하며, 그 다음 중간 위치의 값을 가져와 우리 값과 비교해야 합니다.

2. 중간 값이 주어진 값보다 크다면, 이때 우리의 값이 중간 위치 이전에 있다는 뜻이므로, 우리에게 필요한 값입니다. 변경하는 것은 끝 위치의 값입니다. 이때 끝 위치의 값은 중간 위치여야 합니다.

3. 반대로, 중간 값이 우리가 제공하는 값보다 작다면, 주어진 값이 중간 위치 이후에 있다는 뜻입니다. 이때, 뒷부분의 값을 다시 둘로 나누어야 합니다. 중간 값 이후이기 때문에 값을 변경해야 합니다. 이때 시작 위치의 값은 지정된 값을 찾을 때까지 현재의 중간 위치여야 합니다.

4. 아니면 중간값이 초기 시작 위치나 끝 위치(이 경우 주어진 값을 찾을 수 없음)와 같으면 코드로 구현해 볼까요~


//循环实现
function getValue($num,$arr)
{
  //查找数组的中间位置
  $length=count($arr);
  $start=0;
  $end=$length;
  $middle=floor(($start+$end)/2);
  //循环判断
  while($start>$end-1)
  {
    if($arr[middle]==$num)
    {
      return middle+1;
    } elseif($arr[middle]<$num)
    {
      //如果当前要查找的值比当前数组的中间值还要打,那么意味着该值在数组的后半段
      //所以起始位置变成当前的middle的值,end位置不变。
      $start=$middle;
      $middle=floor(($start+$end)/2);
    } else{
      //反之
      $end=$middle;
      $middle=floor(($start+$end)/2);
    }
  }
  return false;
}


//递归实现
/*
* 从数组中获取元素值
* @param1 int $num,要查找的目标值
* @param2 array $arr,要查找的数组
* @param3 int $start,查找的起始位置
* @param4 int $end,查找的结束位置
* @return mixed,找到了返回位置,没找到返回false
*/
function getValue4($num,$arr,$start = 0,$end = 100){
    //采用二分法查找
    $middle = floor(($end + $start) / 2);
    //判断
    if($arr[$middle] == $num){
      //已经找到了,递归的出口
      return $middle + 1;
    }elseif($arr[$middle] < $num){
      //要查找的元素在数组的后半段
      $start = $middle + 1;
      //边界值
      if($start >= $end){
        //没有找到,但是已经超出边界值,递归出口
        return false;
      }
      //调用自己去查找:递归点
      return getValue4($num,$arr,$start,$end);  //getValue4($num,$arr,51,100)
    }else{
      //要查找的元素在数组的前半段
      $end = $middle - 1;
      //判断边界值
      if($end < 0)return false;
      //调用自己:递归点
      return getValue4($num,$arr,$start,$end);  //getValue4($num,$arr,0,49)
    }
    //都没有找到
    return false;
}

위 내용은 PHP에서 이진 검색 알고리즘을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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