Heim > Backend-Entwicklung > C++ > Hauptteil

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

Patricia Arquette
Freigeben: 2024-10-24 14:05:02
Original
322 Leute haben es durchsucht

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

Verwenden von decltype und einem Lambda Ausdruck:

<code class="cpp">decltype(Compare) myComparator = Compare;
priority_queue<Node, vector<Node>, decltype(Compare)> openSet(myComparator);</code>
Nach dem Login kopieren

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!

Quelle:php
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!