


Sortieren mit Indexerhaltung in C
Im Bereich der Datenmanipulation ist das Sortieren ein grundlegender Vorgang, der Elemente in einer gewünschten Reihenfolge anordnet. Während Sortieralgorithmen von Natur aus die Reihenfolge gleicher Elemente beibehalten, kann es wünschenswert sein, die ursprünglichen Indizes der sortierten Elemente zu verfolgen, um ihren ursprünglichen Kontext beizubehalten.
Ein Ansatz für dieses Problem ist die Verwendung von Lambda-Funktionen in C 11. Ein Lambda ist eine anonyme Funktion, die Variablen aus ihrem umgebenden Bereich erfassen kann. Dies ermöglicht präzise und flexible Sortiervorgänge, die auf externe Daten zugreifen können.
Hier ist eine angepasste Funktion „sort_indexes“, die Lambdas mit dem Algorithmus „stable_sort“ der Standardbibliothek kombiniert:
#include <vector> #include <algorithm> using namespace std; template <typename t> vector<size_t> sort_indexes(const vector<t> &v) { // Initialize original indexes vector<size_t> idx(v.size()); iota(idx.begin(), idx.end(), 0); // Sort indexes based on values in v stable_sort(idx.begin(), idx.end(), [&](size_t i1, size_t i2) { return v[i1] <p>In dieser Funktion beginnen wir Initialisieren Sie einen Vektor idx mit den ursprünglichen Indizes des Eingabevektors v. Anschließend verwenden wir „stable_sort“, um die Indizes basierend auf einem Lambda-Komparator zu sortieren, der die Werte vergleicht in v. Die Verwendung von „stable_sort“ stellt sicher, dass Elemente mit gleichen Werten ihre ursprüngliche Reihenfolge innerhalb des sortierten Ergebnisses beibehalten.</p> <p>Um diese Funktion zu verwenden, übergeben Sie einfach den Vektor der Elemente als Argument und es wird ein sortierter Vektor zurückgegeben Indizes. Bei einem gegebenen Vektor [5, 2, 1, 4, 3] wäre die zurückgegebene Vektor-IDx beispielsweise [1, 2, 4, 3, 0].</p> <p>Mit dieser Technik können Sie Elemente während sortieren Beibehaltung ihrer ursprünglichen Indizes und Bereitstellung von Flexibilität bei nachfolgenden Datenverarbeitungsaufgaben.</p></size_t></t></size_t></typename></algorithm></vector>
Das obige ist der detaillierte Inhalt vonWie kann ich einen Vektor in C sortieren und dabei die Originalindizes beibehalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

In diesem Artikel werden die C -Standard -Vorlagenbibliothek (STL) erläutert, die sich auf seine Kernkomponenten konzentriert: Container, Iteratoren, Algorithmen und Funktoren. Es wird beschrieben, wie diese interagieren, um die generische Programmierung, die Verbesserung der Codeeffizienz und die Lesbarkeit t zu ermöglichen

Dieser Artikel beschreibt die effiziente Verwendung von STL -Algorithmus in c. Es betont die Auswahl der Datenstruktur (Vektoren vs. Listen), Algorithmus -Komplexitätsanalyse (z. B. std :: sortieren vs. std :: partial_sort), Iteratoranwendungen und parallele Ausführung. Häufige Fallstricke wie

In diesem Artikel wird die effektive Ausnahmebehandlung in C, Covering Try, Catch und Wurp Mechanics, beschrieben. Es betont Best Practices wie Raii, die Vermeidung unnötiger Fangblöcke und die Protokollierung von Ausnahmen für robusten Code. Der Artikel befasst sich auch mit Perf

In dem Artikel wird die Verwendung von Move Semantics in C erörtert, um die Leistung zu verbessern, indem unnötiges Kopieren vermieden wird. Es umfasst die Implementierung von Bewegungskonstruktoren und Zuordnungsbetreibern unter Verwendung von STD :: MOVE

C 20 -Bereiche verbessern die Datenmanipulation mit Ausdruckskraft, Komposition und Effizienz. Sie vereinfachen komplexe Transformationen und integrieren sich in vorhandene Codebasen, um eine bessere Leistung und Wartbarkeit zu erhalten.

In dem Artikel wird der dynamische Versand in C, seine Leistungskosten und Optimierungsstrategien erörtert. Es unterstreicht Szenarien, in denen der dynamische Versand die Leistung beeinflusst, und vergleicht sie mit statischer Versand, wobei die Kompromisse zwischen Leistung und Betonung betont werden

Artikel erörtert den effektiven Einsatz von RValue -Referenzen in C für Bewegungssemantik, perfekte Weiterleitung und Ressourcenmanagement, wobei Best Practices und Leistungsverbesserungen hervorgehoben werden. (159 Charaktere)

C Speicherverwaltung verwendet neue, löschende und intelligente Zeiger. In dem Artikel werden manuelle und automatisierte Verwaltung erörtert und wie intelligente Zeiger Speicherlecks verhindern.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

Dreamweaver Mac
Visuelle Webentwicklungstools