Heim >Backend-Entwicklung >C++ >Wie deklariere ich eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator in C korrekt?
Beim Arbeiten mit Prioritätswarteschlangen in C können beim Versuch, sie mit benutzerdefinierten Komparatorfunktionen zu deklarieren, Fehler auftreten. Lassen Sie uns die Gründe für diese Fehler untersuchen und herausfinden, wie Sie eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator richtig deklarieren können.
Wie Sie bereits erwähnt haben, wird versucht, eine Priorität zu deklarieren Warteschlange mit dem folgenden Code löst Fehler aus:
<code class="cpp">priority_queue<Node, vector<Node>, Compare> openSet;</code>
Der Grund für den ersten Fehler („Compare ist kein Typname“) ist, dass Compare voraussichtlich ein Typ ist, insbesondere eine Klasse, die den Operator überschreibt ()-Funktion. Um dieses Problem zu beheben, müssen Sie eine Klasse namens „Compare“ erstellen und „operator()“ darin überladen.
Der zweite Fehler („expected a >'“) tritt auf, wenn die Compare`-Funktion nicht korrekt als a angegeben ist Typ. Um dies zu beheben, ändern Sie die Deklaration wie folgt:
<code class="cpp">priority_queue<Node, vector<Node>, Compare::Compare> openSet;</code>
Hier gibt Compare::Compare explizit die Funktion „operator()“ innerhalb der Compare-Klasse an.
Es gibt alternative Möglichkeiten, eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator zu deklarieren:
Verwenden von std::function:
<code class="cpp">priority_queue<Node, vector<Node>, std::function<bool(Node, Node)>> openSet(Compare);</code>
Verwenden von decltype und einem Lambda Ausdruck:
<code class="cpp">decltype(Compare) myComparator = Compare; priority_queue<Node, vector<Node>, decltype(Compare)> openSet(myComparator);</code>
Das obige ist der detaillierte Inhalt vonWie deklariere ich eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator in C korrekt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!