Heim >Java >javaLernprogramm >Warum spiegelt die PriorityQueue-Methode „toString' von Java nicht die vom Comparator definierte Elementreihenfolge wider?
Wie die toString-Methode von PriorityQueue die Interpretation der Elementreihenfolge in die Irre führt
In Java unterhält die PriorityQueue-Datenstruktur einen binären Heap, um Elemente basierend auf ihrer Zuweisung zu priorisieren Vergleichsstrategie. Diese Strategie wird normalerweise durch einen benutzerdefinierten Komparator implementiert, wie im bereitgestellten Codeausschnitt zu sehen ist. Bei der Untersuchung der Ausgabe der toString-Methode einer PriorityQueue besteht jedoch ein häufiges Missverständnis hinsichtlich der Reihenfolge der Elemente.
Die toString-Methode dient dazu, eine Textdarstellung des Inhalts der PriorityQueue bereitzustellen. Es erzwingt jedoch nicht implizit die vom Komparator definierte Prioritätsreihenfolge. Stattdessen werden die Elemente einfach an ihren aktuellen Positionen im Heap angezeigt, was möglicherweise nicht mit der erwarteten Sortierreihenfolge übereinstimmt.
Im angegebenen Beispiel wird die PriorityQueue mit einem benutzerdefinierten Komparator initialisiert, um Häufigkeitswerte zu priorisieren. Sie wollten, dass die Ausgabe diese Reihenfolge widerspiegelt, wobei Elemente mit niedrigeren Frequenzen zuerst aufgeführt werden. Die Ausgabe der toString-Methode zeigt jedoch eine falsche Reihenfolge an, was offenbar im Widerspruch zur beabsichtigten Priorität steht.
Die Ursache dieser Diskrepanz liegt in der internen Struktur eines binären Heaps. Während eine teilweise Reihenfolge beibehalten wird, werden die Elemente erst dann vollständig sortiert, wenn sie aus dem Heap entfernt werden. Die toString-Methode ruft die Elemente direkt aus dem Heap ab, ohne diese Sortierung durchzuführen, was zur beobachteten Ausgabe führt.
Um dieses Problem zu beheben und die richtige Sortierreihenfolge zu erhalten, ist es notwendig, die Elemente einzeln aus der PriorityQueue zu extrahieren eins. Die Methode poll() erledigt dies, indem sie ein Element aus dem Heap entfernt und es zurückgibt. Indem Sie die PriorityQueue mit poll() durchlaufen und die zurückgegebenen Elemente drucken, können Sie die gewünschte sortierte Reihenfolge erhalten.
Daher wäre der richtige Code zum Drucken der Elemente in sortierter Reihenfolge:
<code class="java">while (!queue.isEmpty()) { System.out.println(queue.poll()); }</code>
Dadurch werden die Elemente in aufsteigender Reihenfolge ihrer Häufigkeit gedruckt, wie vom Komparator definiert.
Das obige ist der detaillierte Inhalt vonWarum spiegelt die PriorityQueue-Methode „toString' von Java nicht die vom Comparator definierte Elementreihenfolge wider?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!