В чем разница между SplHeap, SplMinHeap, SplMaxHeap и SplPriorityQueue
Есть куча объектов, которые мне нужно пройти в отсортированном порядке. Обнаружил два подкласса SplHeap, SplMaxHeap и SplMinHeap, поэтому решил, что я могу попытаться использовать их в качестве эксперимента. В комментарии я также прочитал упомянутое SplPriorityQueue.
Однако, попробовав их, я немного не уверен, в чем именно разница между тремя кучами и как выбирать между кучами и очередью.
Вот "4" класса, которые все будут сортировать объекты по имени, т.е. foreach
Цикл будет перечислять объекты в правильно отсортированном порядке, от первого до последнего:
class SortedObjectHeap extends SplHeap|SplMinHeap|SplMaxHeap
{
protected $_property;
public function __construct(string $property)
{
$this->_property = $property;
}
protected function compare($x, $y)
{
$x = $x->{$this->_property} ?? null;
$y = $y->{$this->_property} ?? null;
return strnatcasecmp($x, $y) * -1;
}
}
$list = new SortedObjectHeap('name');
$list->insert($object);
// ...
class SortedObjectQueue extends SplPriorityQueue
{
public function compare($x, $y)
{
return strnatcasecmp($x, $y) * -1;
}
}
$list = new SortedObjectQueue();
$list->insert($object, $object->name);
// ...
Вопросы:
Для
SortedObjectHeap
порядок выглядит точно так же, независимо от того, продлил ли яSplHeap
,SplMaxHeap
или жеSplMinHeap
, Я думал, что при переключении между Min и Max порядок изменится, но, похоже, этого не происходит... так в чем же разница между расширением этих 3 классов?Из документов, очевидная разница между
SplHeap
а такжеSplPriorityQueue
является то, что очередь занимает дополнительную$priority
параметр вinsert
метод. Таким образом, кажется, что с очередью вы должны сказать ей, что сортировать на каждой вставке, в то время как с кучей она "знает" это внутренне... Это различие или есть другие важные различия между этими двумя? Я предполагаю, что они могут работать по-другому внутри? Как выбрать между этими двумя?
1 ответ
Причина того, что SplMinHeap
а также SplMaxHeap
вернуть тот же порядок, что вы даете им обеим одну и ту же функцию сравнения. Но SplMinHeap::Compare и SplMaxHeap.Compare определяются по-разному.
SplMinHeap::Compare
возвращает положительное целое число, если value1 < value2
, SplMaxHeap::Compare
возвращает положительное целое число, если value1 > value2
,
Ты используешь SplMinHeap
или же SplMaxHeap
если вам нужна куча, упорядоченная по "естественному" порядку элемента. Как вы хотите создать упорядоченный список строк. Какой из них вы используете, зависит от того, хотите ли вы в порядке возрастания или убывания.
Ты используешь SplPriorityQueue
если вы хотите связать приоритет с каждым элементом и иметь кучу, упорядоченную по приоритету. Например, у вас есть несколько имен, но вы хотите, чтобы они были расположены в том порядке, в котором они были вставлены в систему. Итак, Джо, Билли, Мэри и Алиса появились в таком порядке, вы бы дали Джо приоритет 1, Билли приоритет 2 и т. Д.
Но если все, что вам нужно, это отсортированный список строк, почему бы просто не отсортировать их и покончить с этим? Это будет быстрее, чем заполнять кучу и извлекать элементы по одному.