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

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

DDD
DDDOriginal
2024-10-24 13:31:02391Durchsuche

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

Deklarieren einer Prioritätswarteschlange mit einem benutzerdefinierten Komparator in C

Wenn Sie in C versuchen, eine Prioritätswarteschlange zu deklarieren, die einen benutzerdefinierten Komparator verwendet, Es ist wichtig, den Komparator richtig zu definieren. Der Fehler „Compare“ ist kein Typname tritt auf, wenn der Komparator nicht als Klasse oder eigenständige Funktion deklariert ist.

Um dieses Problem zu beheben, können Sie eine Klasse für den Komparator definieren und den Operator() für überladen es, wie im folgenden Beispiel gezeigt:

<code class="cpp">class Compare
{
public:
    bool operator() (Node a, Node b)
    {
        // Comparator logic
    }
};</code>

Alternativ können Sie eine std::function verwenden, um den Komparator zu definieren, wie unten gezeigt:

<code class="cpp">bool Compare(Node a, Node b)
{
    // Comparator logic
}

std::priority_queue<Node, std::vector<Node>, std::function<bool(Node, Node)>> pq(Compare);</code>

Indem Sie diese Ansätze befolgen , können Sie mit einem benutzerdefinierten Komparator in C effektiv eine Prioritätswarteschlange deklarieren.

Das obige ist der detaillierte Inhalt vonWie deklariere ich eine Prioritätswarteschlange mit einem benutzerdefinierten Komparator in C?. 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