Vektorgröße in C verstehen
In C ist die Vektordatenstruktur ein dynamisches Array, das seine Größe automatisch anpassen kann, wenn Elemente hinzugefügt werden oder entfernt. Bei der Arbeit mit Vektoren ist es jedoch wichtig, das Verhalten von size() zu verstehen, wenn der Vektor leer ist.
Warum size() - 1 für einen leeren Vektor nicht -1 ist
Beachten Sie den bereitgestellten Codeausschnitt:
#include <vector> #include <iostream> using namespace std; int main() { vector<int> value; cout << value.size() << endl; // output 0 cout << value.size() - 1 << endl; // output 18446744073709551615 }
Die erste Ausgabe, 0, stellt die Anzahl der Elemente im leeren Vektor korrekt dar. Allerdings ist die zweite Ausgabe, die 1 von der Größe subtrahiert, unerwartet, da sie eine große Ganzzahl ohne Vorzeichen anstelle von -1 zurückgibt.
Der Grund für dieses Verhalten liegt im Typ von size_t, der in vector::size verwendet wird (). size_t ist ein vorzeichenloser Ganzzahltyp, der zum Speichern der Anzahl der Elemente in einem Vektor entwickelt wurde. Vorzeichenlose Ganzzahlen können keine negativen Zahlen darstellen, daher führt jeder Versuch, 1 von 0 zu subtrahieren, zu einem großen vorzeichenlosen Ganzzahlwert.
Fazit
Es ist wichtig, sich daran zu erinnern, dass size_t dies ist ein vorzeichenloser Typ und kann keine negativen Zahlen darstellen. Berücksichtigen Sie bei der Arbeit mit Vektoren immer die Möglichkeit großer vorzeichenloser Ganzzahlwerte, wenn Sie 1 von der Größe eines leeren Vektors subtrahieren.
Das obige ist der detaillierte Inhalt vonWarum gibt „vector.size() - 1' nicht -1 für einen leeren Vektor in C zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!