Verwenden von std::sort zum Sortieren von Arrays in C
Dieser Artikel befasst sich mit der Verwendung der Standard Template Library (STL)-Funktion std: :sort, um ein als int v[2000] deklariertes Array zu sortieren. Darüber hinaus wird untersucht, ob C eine native Möglichkeit bietet, die Anfangs- und Endindizes eines Arrays zu erhalten.
std::sort und bereichsbasierte Sortierung
Zu verwenden Mit std::sort können Sie die in C 11 eingeführte bereichsbasierte for-Schleife nutzen. Dieser Ansatz vereinfacht den Sortiervorgang:
<code class="cpp">int v[2000]; std::sort(std::begin(v), std::end(v));</code>
Wobei std::begin und std::end Dienstprogrammfunktionen sind, die zurückkehren Iteratoren, die auf das erste bzw. auf das letzte Element eines Containers oder Arrays verweisen.
Benutzerdefinierte Anfangs- und Endfunktionen
Für frühere C-Versionen können Sie erstellen Ihre eigenen Anfangs- und Endfunktionen:
<code class="cpp">template<class Cont> typename Cont::iterator begin(Cont& c){ return c.begin(); } template<class Cont> typename Cont::iterator end(Cont& c){ return c.end(); } 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>
Diese Funktionen überladen die vorhandenen Anfangs- und Endfunktionen für Container und Arrays und bieten eine konsistente Schnittstelle für den Zugriff auf Bereichsgrenzen.
Das obige ist der detaillierte Inhalt vonKann ich Array-Grenzen mit nativen C-Funktionen erhalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!