Heim > php教程 > PHP开发 > Hauptteil

Löschvorgang des Vektors

高洛峰
Freigeben: 2016-11-22 15:24:08
Original
1668 Leute haben es durchsucht

Kürzlich habe ich beim Lesen eines Buches zufällig ein Detail entdeckt: den Löschvorgang von Vektoren. Für diesen Löschvorgang weiß jeder, dass dieser Löschvorgang zwei Formen hat: (1) Löschen eines einzelnen Elements, der Parameter ist eine Iteratorvariable, (2) Löschen eines Intervallelements, die Parameter sind Anfang und Ende. Die Details sind die spezifischen Dinge, die passieren, wenn ein einzelnes Element gelöscht wird.

Beispiel: Es gibt einen Vektor, der wie folgt initialisiert wird: vector lösche die Elemente im Vektor, die gleich sind zu 2!

Normalerweise wird der Code so geschrieben:

#include <vector>
 #include <iostream>

int main() {     std::vector<int> va{ 1,2,3,4,4,5,6 };     std::vector<int> vb(va);     for (auto i = va.begin();i != va.end(); i++)     {         if (*i == 4)         {             i = va.erase(i);         }     }     for (auto i : va) { std::cout << i << "  "; }     return 0; }
Nach dem Login kopieren

Auf den ersten Blick ist nichts falsch, aber das Ergebnis ist unerwartet

Löschvorgang des Vektors

Warum ist das Ergebnis so? Nach sorgfältiger Überlegung stellt sich heraus, dass beim Löschen ein Fehler aufgetreten ist. Wenn die if-Bedingung erfüllt ist, führt der Vektor einen Löschvorgang aus und löscht die Elemente im Vektor, die die Bedingungen erfüllen Führt den Löschvorgang aus, stellt der zurückgegebene Wert die nächste Position des aktuell gelöschten Iterators dar. Wenn die Schleife dann erneut wiederholt wird, bewegt sich der Iterator um eine Position zurück, wodurch dasselbe Element gelöscht wird.

Anbei die korrekte Schreibweise:

#include <vector> #include <iostream>

int main() {     std::vector<int> va{ 1,2,3,4,4,5,6 };     std::vector<int> vb(va);     auto iter = vb.begin();     while(iter!=vb.end())     {         if (iter != vb.end())         {             if (*iter == 4)             {                 iter = vb.erase(iter);             }             else 
            { iter++; }         }     }     for (auto j : vb)     {         std::cout << j << "  ";     }     return 0; }
Nach dem Login kopieren
#include <vector>  #include <iostream>


int main() {     std::vector<int> va{ 1,2,3,4,4,5,6 };     for (auto i = va.begin();i != va.end(); )     {         if (*i == 4)         {             i = va.erase(i);         }         else { i++; }     }     for (auto i : va)     {         std::cout << i << "  ";     }     return 0; }
Nach dem Login kopieren


Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!