Erstellen eines Subvektors aus einem Vektor
In C, wenn Sie einen vorhandenen Vektor der Größe N (myVec) haben und dies wünschen Um daraus einen Subvektor zu extrahieren, der Elemente von Index wird mit O(N)-Komplexität durchgeführt.
vector<T>::const_iterator first = myVec.begin() + X;
vector<T>::const_iterator last = myVec.begin() + Y + 1;
vector<T> newVec(first, last);
Alternative STL-Datentypen
Wenn die Effizienz im Vordergrund steht und die O(N)-Leistung nicht akzeptabel ist, können andere STL-Datenstrukturen dies tun berücksichtigt:
std::deque:
Eine doppelendige Warteschlange, die eine effiziente Einfügung ermöglicht und Löschung an beiden Enden. Der Zugriff auf Elemente an beliebigen Positionen innerhalb einer Deque ist jedoch weniger effizient als mit einem Vektor.-
std::list:
Eine doppelt verknüpfte Liste, die effizientes Einfügen und Löschen an jeder Position unterstützt. Es ermöglicht zwar den Zugriff auf beliebige Elemente, hat aber im Vergleich zu einem Vektor einen höheren Speicheraufwand.-
Die Wahl zwischen einem Vektor, einer Deque oder einer Liste hängt letztendlich von den spezifischen Leistungsanforderungen und Zugriffsmustern Ihres Browsers ab Anwendung.
Das obige ist der detaillierte Inhalt vonWie erstellt man effizient einen Subvektor in C?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
Stellungnahme: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