To have a good idea what you can do with SplHeap, I created a little example script that will show the rankings of Belgian soccer teams in the Jupiler League.
<?php
/**
* A class that extends SplHeap for showing rankings in the Belgian
* soccer tournament JupilerLeague
*/
class JupilerLeague extends SplHeap
{
/**
* We modify the abstract method compare so we can sort our
* rankings using the values of a given array
*/
public function compare($array1, $array2)
{
$values1 = array_values($array1);
$values2 = array_values($array2);
if ($values1[0] === $values2[0]) return 0;
return $values1[0] < $values2[0] ? -1 : 1;
}
}
// Let's populate our heap here (data of 2009)
$heap = new JupilerLeague();
$heap->insert(array ('AA Gent' => 15));
$heap->insert(array ('Anderlecht' => 20));
$heap->insert(array ('Cercle Brugge' => 11));
$heap->insert(array ('Charleroi' => 12));
$heap->insert(array ('Club Brugge' => 21));
$heap->insert(array ('G. Beerschot' => 15));
$heap->insert(array ('Kortrijk' => 10));
$heap->insert(array ('KV Mechelen' => 18));
$heap->insert(array ('Lokeren' => 10));
$heap->insert(array ('Moeskroen' => 7));
$heap->insert(array ('Racing Genk' => 11));
$heap->insert(array ('Roeselare' => 6));
$heap->insert(array ('Standard' => 20));
$heap->insert(array ('STVV' => 17));
$heap->insert(array ('Westerlo' => 10));
$heap->insert(array ('Zulte Waregem' => 15));
// For displaying the ranking we move up to the first node
$heap->top();
// Then we iterate through each node for displaying the result
while ($heap->valid()) {
list ($team, $score) = each ($heap->current());
echo $team . ': ' . $score . PHP_EOL;
$heap->next();
}
?>
This results in the following output:
Club Brugge: 21
Anderlecht: 20
Standard: 20
KV Mechelen: 18
STVV: 17
Zulte Waregem: 15
AA Gent: 15
G. Beerschot: 15
Charleroi: 12
Racing Genk: 11
Cercle Brugge: 11
Kortrijk: 10
Lokeren: 10
Westerlo: 10
Moeskroen: 7
Roeselare: 6
Hope this example paved the way for more complex implementations of SplHeap.
La clase SplHeap
(PHP 5 >= 5.3.0)
Introducción
La clase SplHeap proporciona las básicas funcionalidades de un Heap.
Sinopsis de la Clase
/* Métodos */
__construct
( void
)
}Tabla de contenidos
- SplHeap::compare — Compara elementos con el fin de colocarlos correctamente en el montón en la parte de arriba
- SplHeap::__construct — Construye un nuevo heap vacío
- SplHeap::count — Cuenta el número de elementos en el montón
- SplHeap::current — Devuelve el nodo actual señalado por el iterador
- SplHeap::extract — Extrae un nodo de la parte superior del montón
- SplHeap::insert — Inserta un elemento en el montón
- SplHeap::isEmpty — Comprueba si el montón actual está vacío
- SplHeap::key — Devuelve el índice de el nodo actual
- SplHeap::next — Mover al siguiente nodo
- SplHeap::recoverFromCorruption — Recuperarse de un estado dañado y permitir un mayor número de acciones en el montón
- SplHeap::rewind — Rebobina el iterador al comienzo
- SplHeap::top — Observar el nodo desde el comienzo del montón
- SplHeap::valid — Comprueba si el montón contiene más nodos
Michelangelo van Dam ¶
3 years ago
