Ein Vektor kann mehrere Datenwerte wie Arrays speichern, sie können jedoch nur Objektreferenzen und keine primitiven Datentypen speichern. Sie speichern die Referenz eines Objekts, das heißt, sie verweisen auf die Objekte, die die Daten enthalten, anstatt sie zu speichern. Im Gegensatz zu einem Array müssen Vektoren nicht mit der Größe initialisiert werden. Sie haben die Flexibilität, sich an die Anzahl der Objektreferenzen anzupassen, was möglich ist, weil ihre Speicherung automatisch vom Container verwaltet wird. Der Container behält eine interne Kopie von alloc, die zur lebenslangen Zuweisung von Speicher verwendet wird. Vektoren können mithilfe von Iteratoren lokalisiert und durchlaufen werden, sodass sie in einem zusammenhängenden Speicher abgelegt werden. Im Gegensatz zu Array verfügt Vector auch über Sicherheitsfunktionen, die verhindern, dass Programme abstürzen. Wir können Vektoren Reserveraum geben, Arrays jedoch nicht. Ein Array ist keine Klasse, aber ein Vektor ist eine Klasse. In Vektoren können Elemente gelöscht werden, in Arrays jedoch nicht.
Mit der übergeordneten „Collection-Klasse“ wird der Vektor in Form einer Vorlagenklasse gesendet. Das Array ist die Datenstruktur der unteren Ebene mit ihren spezifischen Eigenschaften. Vektoren haben Funktionen und Konstruktoren; Sie sind nicht indexbasiert. Sie sind das Gegenteil von Arrays, bei denen es sich um indexbasierte Datenstrukturen handelt. Hier wird dem ersten Element die niedrigste Adresse und dem letzten Element die höchste Adresse bereitgestellt. Vektoren werden zum Einfügen und Löschen eines Objekts verwendet, während Arrays für den häufigen Zugriff auf Objekte verwendet werden. Arrays sind speichersparende Datenstrukturen, während Vector im Gegenzug viel mehr Speicher nutzt, um den Speicher zu verwalten und dynamisch zu wachsen. Vector benötigt mehr Zeit, um auf die Elemente zuzugreifen, was bei Arrays jedoch nicht der Fall ist.
Es gibt vier Möglichkeiten, a zu initialisieren Vektor in C++ :
- Indem Sie die Werte einzeln eingeben
- Durch Verwendung eines überladenen Konstruktors der Vektorklasse
- Mithilfe von Arrays
- Durch Verwendung eines anderen initialisierten Vektors
Indem Sie die Werte einzeln eingeben -
Alle Elemente in einem Vektor können einzeln mit der Vektorklassenmethode „push_back“ eingefügt werden.
Algorithmus
Begin Declare v of vector type. Then we call push_back() function. This is done to insert values into vector v. Then we print 'Vector elements: '. ' for (int a: v) print all the elements of variable a.'
Code -
#include #include using namespace std; int main() { vector vec; vec.push_back(1); vec.push_back(2); vec.push_back(3); vec.push_back(4); vec.push_back(5); vec.push_back(6); vec.push_back(7); vec.push_back(8); vec.push_back(9); vec.push_back(101); for (int i = 0; i <vec.size(); i++) { cout << vec[i] ' '; } return 0; < pre> <p> <strong>Output</strong> </p> <img src="//techcodeview.com/img/c-tutorial/62/initialize-vector-c.webp" alt="Initialize Vector in C++"> <h3>Using an overloaded constructor -</h3> <p>When a vector has multiple elements with the same values, then we use this method.</p> <p>By using an overloaded constructor of the vector class -</p> <p>This method is mainly used when a vector is filled with multiple elements with the same value.</p> <p> <strong>Algorithm</strong> </p> <pre> Begin First, we initialize a variable say 's'. Then we have to create a vector say 'v' with size's'. Then we initialize vector v1. Then initialize v2 by v1. Then we print the elements. End. </pre> <p> <strong>Code -</strong> </p> <pre> #include #include using namespace std; int main() { int elements = 12; vector vec(elements, 8); for (int i = 0; i <vec.size(); i++) { cout << vec[i] ' '; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 8 8 8 8 8 8 8 8 8 8 8 8 </pre> <h3>By the help of arrays -</h3> <p>We pass an array to the constructor of the vector class. The Array contains the elements which will fill the vector.</p> <p> <strong>Algorithm -</strong> </p> <pre> Begin First, we create a vector say v. Then, we initialize the vector. In the end, print the elements. End. </pre> <p> <strong>Code -</strong> </p> <pre> #include #include using namespace std; int main() { vector vectr{9,8,7,6,5,4,3,2,1,0}; for (int i = 0; i <vectr.size(); i++) { cout << vectr[i] ' '; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 9 8 7 6 5 4 3 2 1 0 </pre> <h3>Using another initialized vector -</h3> <p>Here, we have to pass the begin() and end() iterators of an initialized vector to a vector class constructor. Then we initialize a new vector and fill it with the old vector.</p> <p> <strong>Algorithm -</strong> </p> <pre> Begin First, we have to create a vector v1. Then, we have to initialize vector v1 by an array. Then we initialize vector v2 by v1. We have to print the elements. End. </pre> <p> <strong>Code -</strong> </p> <pre> #include #include using namespace std; int main() { vector vec_1{1,2,3,4,5,6,7,8}; vector vec_2(vec_1.begin(), vec_1.end()); for (int i = 0; i <vec_2.size(); i++) { cout << vec_2[i] ' '; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 1 2 3 4 5 6 7 8 </pre> <hr></vec_2.size();></pre></vectr.size();></pre></vec.size();></pre></vec.size();>
Code -
#include #include using namespace std; int main() { int elements = 12; vector vec(elements, 8); for (int i = 0; i <vec.size(); i++) { cout << vec[i] \' \'; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 8 8 8 8 8 8 8 8 8 8 8 8 </pre> <h3>By the help of arrays -</h3> <p>We pass an array to the constructor of the vector class. The Array contains the elements which will fill the vector.</p> <p> <strong>Algorithm -</strong> </p> <pre> Begin First, we create a vector say v. Then, we initialize the vector. In the end, print the elements. End. </pre> <p> <strong>Code -</strong> </p> <pre> #include #include using namespace std; int main() { vector vectr{9,8,7,6,5,4,3,2,1,0}; for (int i = 0; i <vectr.size(); i++) { cout << vectr[i] \' \'; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 9 8 7 6 5 4 3 2 1 0 </pre> <h3>Using another initialized vector -</h3> <p>Here, we have to pass the begin() and end() iterators of an initialized vector to a vector class constructor. Then we initialize a new vector and fill it with the old vector.</p> <p> <strong>Algorithm -</strong> </p> <pre> Begin First, we have to create a vector v1. Then, we have to initialize vector v1 by an array. Then we initialize vector v2 by v1. We have to print the elements. End. </pre> <p> <strong>Code -</strong> </p> <pre> #include #include using namespace std; int main() { vector vec_1{1,2,3,4,5,6,7,8}; vector vec_2(vec_1.begin(), vec_1.end()); for (int i = 0; i <vec_2.size(); i++) { cout << vec_2[i] \' \'; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 1 2 3 4 5 6 7 8 </pre> <hr></vec_2.size();></pre></vectr.size();></pre></vec.size();>
Mit Hilfe von Arrays -
Wir übergeben ein Array an den Konstruktor der Vektorklasse. Das Array enthält die Elemente, die den Vektor füllen.
Algorithmus -
Begin First, we create a vector say v. Then, we initialize the vector. In the end, print the elements. End.
Code -
#include #include using namespace std; int main() { vector vectr{9,8,7,6,5,4,3,2,1,0}; for (int i = 0; i <vectr.size(); i++) { cout << vectr[i] \' \'; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 9 8 7 6 5 4 3 2 1 0 </pre> <h3>Using another initialized vector -</h3> <p>Here, we have to pass the begin() and end() iterators of an initialized vector to a vector class constructor. Then we initialize a new vector and fill it with the old vector.</p> <p> <strong>Algorithm -</strong> </p> <pre> Begin First, we have to create a vector v1. Then, we have to initialize vector v1 by an array. Then we initialize vector v2 by v1. We have to print the elements. End. </pre> <p> <strong>Code -</strong> </p> <pre> #include #include using namespace std; int main() { vector vec_1{1,2,3,4,5,6,7,8}; vector vec_2(vec_1.begin(), vec_1.end()); for (int i = 0; i <vec_2.size(); i++) { cout << vec_2[i] \' \'; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 1 2 3 4 5 6 7 8 </pre> <hr></vec_2.size();></pre></vectr.size();>
Verwenden eines anderen initialisierten Vektors -
Hier müssen wir die Iteratoren begin() und end() eines initialisierten Vektors an einen Vektorklassenkonstruktor übergeben. Dann initialisieren wir einen neuen Vektor und füllen ihn mit dem alten Vektor.
Algorithmus -
Begin First, we have to create a vector v1. Then, we have to initialize vector v1 by an array. Then we initialize vector v2 by v1. We have to print the elements. End.
Code -
#include #include using namespace std; int main() { vector vec_1{1,2,3,4,5,6,7,8}; vector vec_2(vec_1.begin(), vec_1.end()); for (int i = 0; i <vec_2.size(); i++) { cout << vec_2[i] \\' \\'; } return 0; < pre> <p> <strong>Output</strong> </p> <pre> 1 2 3 4 5 6 7 8 </pre> <hr></vec_2.size();>