Heim  >  Artikel  >  Backend-Entwicklung  >  Wie deklariere ich eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator in C korrekt?

Wie deklariere ich eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator in C korrekt?

Patricia Arquette
Patricia ArquetteOriginal
2024-10-24 14:05:02323Durchsuche

How to Correctly Declare a Priority Queue with a Custom Comparator in C  ?

Deklarieren einer Prioritätswarteschlange in C mit einem benutzerdefinierten Komparator

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.

Falsche Deklaration: Ursachen und Lösungen

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.

Alternative Deklarationsoptionen

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn