Heim > Backend-Entwicklung > C++ > Anleitung: Sortieren eines Arrays mit std::sort in C

Anleitung: Sortieren eines Arrays mit std::sort in C

Barbara Streisand
Freigeben: 2024-10-23 21:00:02
Original
938 Leute haben es durchsucht

How to: Sort an Array Using std::sort in C

Array mit std::sort in C sortieren

In C stellt die Standardvorlagenbibliothek die Funktion std::sort() bereit, um Elemente in einem Array effizient zu sortieren . Für ein als int v[2000] deklariertes Array zeigt das folgende Codefragment, wie man std::sort() verwendet, um dies zu erreichen:

<code class="cpp">#include <algorithm>

int main() {
  int v[2000];
  std::sort(std::begin(v), std::end(v));
}</code>
Nach dem Login kopieren

Allerdings sind std::begin() und std: Die in C 0x/11 eingeführten :end()-Funktionen sind für diesen Ansatz unerlässlich. Diese Funktionen geben Iteratoren zurück, die den Anfang und das Ende eines bestimmten Containers einschließlich Arrays darstellen.

Wenn Sie keinen Zugriff auf C 0x haben, können Sie diese Funktionen selbst definieren:

Anfangsfunktion für nicht konstante Container:

<code class="cpp">template<class Cont>
typename Cont::iterator begin(Cont& c) {
  return c.begin();
}</code>
Nach dem Login kopieren

Endfunktion für nicht konstante Container:

<code class="cpp">template<class Cont>
typename Cont::iterator end(Cont& c) {
  return c.end();
}</code>
Nach dem Login kopieren

Anfangsfunktion für const-Container:

<code class="cpp">template<class Cont>
typename Cont::const_iterator begin(Cont const& c) {
  return c.begin();
}</code>
Nach dem Login kopieren

Endfunktion für const-Container:

<code class="cpp">template<class Cont>
typename Cont::const_iterator end(Cont const& c) {
  return c.end();
}</code>
Nach dem Login kopieren

Überladungen für Arrays im C-Stil:

<code class="cpp">template<class T, std::size_t N>
T* begin(T (&arr)[N]) {
  return &arr[0];
}

template<class T, std::size_t N>
T* end(T (&arr)[N]) {
  return arr + N;
}</code>
Nach dem Login kopieren

Mithilfe dieser Funktionen können Sie ein Array nahtlos mit std::sort() in C sortieren.

Das obige ist der detaillierte Inhalt vonAnleitung: Sortieren eines Arrays mit std::sort in C. 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