quick implementation of SPL Priority Queue:
<?php
class PQtest extends SplPriorityQueue
{
public function compare($priority1, $priority2)
{
if ($priority1 === $priority2) return 0;
return $priority1 < $priority2 ? -1 : 1;
}
}
$objPQ = new PQtest();
$objPQ->insert('A',3);
$objPQ->insert('B',6);
$objPQ->insert('C',1);
$objPQ->insert('D',2);
echo "COUNT->".$objPQ->count()."<BR>";
//mode of extraction
$objPQ->setExtractFlags(PQtest::EXTR_BOTH);
//Go to TOP
$objPQ->top();
while($objPQ->valid()){
print_r($objPQ->current());
echo "<BR>";
$objPQ->next();
}
?>
output:
COUNT->4
Array ( [data] => B [priority] => 6 )
Array ( [data] => A [priority] => 3 )
Array ( [data] => D [priority] => 2 )
Array ( [data] => C [priority] => 1 )
la clase SplPriorityQueue
(PHP 5 >= 5.3.0)
Introducción
la clase SplPriorityQueue proporciona las principales funcionalidades de una cola de prioridad, implementado usando una pila.
Sinopsis de la Clase
/* Métodos */
__construct
( void
)
}Tabla de contenidos
- SplPriorityQueue::compare — Comparar las prioridades con el fin de colocar los elementos correctamente en el montón, mientras que tamizar arriba
- SplPriorityQueue::__construct — Construye una nueva cola vacía
- SplPriorityQueue::count — Cuenta el número de elementos en la cola
- SplPriorityQueue::current — Volver nodo actual que apunta el iterador
- SplPriorityQueue::extract — Extrae un nodo de la parte superior de la pila y filtra hacía arriba
- SplPriorityQueue::insert — Inserta un elemento en la cola en la parte de arriba
- SplPriorityQueue::isEmpty — Comprueba si la cola está vacía
- SplPriorityQueue::key — Devuelve el índice del nodo actual
- SplPriorityQueue::next — Pasar a la siguiente nodo
- SplPriorityQueue::recoverFromCorruption — Recuperar desde la condición corrupta y permitir acciones más en la cola
- SplPriorityQueue::rewind — Rebobinar iterador de vuelta al inicio (no-op)
- SplPriorityQueue::setExtractFlags — Establece el modo de extracción
- SplPriorityQueue::top — Mira en el nodo de la parte superior de la cola
- SplPriorityQueue::valid — Comprobar si la cola contiene más nodos
rajatn at rediff dot co dot in ¶
2 years ago
