Heim > Backend-Entwicklung > PHP-Tutorial > Vergleich der Algorithmuseffizienz für die Suche nach bestimmten Elementen in PHP-Arrays

Vergleich der Algorithmuseffizienz für die Suche nach bestimmten Elementen in PHP-Arrays

PHPz
Freigeben: 2024-05-01 11:03:01
Original
617 Leute haben es durchsucht

PHP-Array-Element-Suchalgorithmus-Effizienzvergleich: lineare Suche: die Effizienz im ungeordneten Array ist O(n); binäre Suche (geordnetes Array): Zeitkomplexität ist O(log n); , unabhängig vom Array-Typ.

Vergleich der Algorithmuseffizienz für die Suche nach bestimmten Elementen in PHP-Arrays

Vergleich der Algorithmuseffizienz zum Finden spezifischer Elemente in PHP-Arrays

Das Finden spezifischer Elemente in einem Array ist eine häufige Aufgabe in PHP und für diesen Zweck stehen verschiedene Algorithmen zur Verfügung. In diesem Artikel wird die Effizienz der drei häufigsten Algorithmen verglichen:

Lineare Suche

function linearSearch($arr, $target) {
  for ($i = 0; $i < count($arr); $i++) {
    if ($arr[$i] === $target) {
      return $i;
    }
  }

  return -1;
}
Nach dem Login kopieren

2. Binäre Suche (Array muss geordnet sein)

function binarySearch($arr, $target) {
  $left = 0;
  $right = count($arr) - 1;

  while ($left <= $right) {
    $mid = floor(($left + $right) / 2);

    if ($arr[$mid] === $target) {
      return $mid;
    } else if ($arr[$mid] < $target) {
      $left = $mid + 1;
    } else {
      $right = $mid - 1;
    }
  }

  return -1;
}
Nach dem Login kopieren

Hash-Tabelle Nach Durch die Verwendung von Schlüssel-Wert-Paaren zum Speichern von Daten können Suchvorgänge erheblich schneller erfolgen.

function hashTableSearch($arr, $target) {
  $lookupTable = [];

  for ($i = 0; $i < count($arr); $i++) {
    $lookupTable[$arr[$i]] = true;
  }

  if (isset($lookupTable[$target])) {
    return true;
  } else {
    return false;
  }
}
Nach dem Login kopieren

Praktischer Fall

Wir haben verschiedene Array-Größen zum Testen verwendet, ungeordnete Arrays und geordnete Arrays mit zufälligen Elementen. Die Ergebnisse sind wie folgt:

AlgorithmusUngeordnetes ArrayGeordnetes ArrayLinear. SucheO(n)O(n) Binäre SucheO( log n)O(log n)Hash-TabelleO(1)O(1)Fazit

Die binäre Suche funktioniert am besten in geordneten Arrays und hat eine komplexe Zeit Der Grad ist O(log n), während Hash-Tabellen in allen Fällen am effizientesten sind und die Zeitkomplexität immer O(1) ist.

Das obige ist der detaillierte Inhalt vonVergleich der Algorithmuseffizienz für die Suche nach bestimmten Elementen in PHP-Arrays. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
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
Aktuelle Ausgaben
PHP-Datenerfassung?
Aus 1970-01-01 08:00:00
0
0
0
PHP-Erweiterung intl
Aus 1970-01-01 08:00:00
0
0
0
Wie man PHP gut lernt
Aus 1970-01-01 08:00:00
0
0
0
Mehrere PHP-Versionen
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage