Heim > Backend-Entwicklung > PHP-Tutorial > Teilen Sie die Methode zur Implementierung des Halbabfragealgorithmus in PHP

Teilen Sie die Methode zur Implementierung des Halbabfragealgorithmus in PHP

黄舟
Freigeben: 2023-03-16 14:16:01
Original
1062 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich den in PHP implementierten Halbabfragealgorithmus vor und analysiert die Algorithmusoperationsschritte und Verwendungsmethoden von PHP unter Verwendung rekursiver und nicht rekursiver Halbabfragen in Form eines vollständigen Beispiels.

Das Beispiel in diesem Artikel beschreibt den in PHP implementierten Half-Query-Algorithmus. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Was ist der Halbabfragealgorithmus? Beschreiben Sie sich in Baidu mit konkreten Worten. Geben Sie direkt den Code ein:


<?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 &#39;检索范围:&#39;.$startIndex.&#39; ~ &#39;.$endIndex.&#39;<br>检索位置:&#39;.$searchIndex.&#39;检索值为:&#39;.$data[$searchIndex];
  echo &#39;<br>=======================<br><br>&#39;;
  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 &#39;检索范围:&#39;.$startIndex.&#39; ~ &#39;.$endIndex.&#39;<br>检索位置:&#39;.$searchIndex.&#39;检索值为:&#39;.$data[$searchIndex];
 echo &#39;<br>=======================<br><br>&#39;;
 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 &#39;结果:&#39;.$index;
Nach dem Login kopieren

Laufergebnis:

Das obige ist der detaillierte Inhalt vonTeilen Sie die Methode zur Implementierung des Halbabfragealgorithmus in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage