Initializing Vector using an Existing Vector in C++ STL
Last Updated :
08 Mar, 2023
A vector is a type of container which can store objects of similar data type. Vector acts like a dynamic array where we can insert elements and the size of the array increases depending upon the elements inserted.
Syntax:
vector<data_structure/type> vector_name(size, item)
To know more about vectors refer to vectors in C++.
The 3D vector in C++
A 3D vector is a type of multidimensional vector having 3 dimensions. It can also be interpreted as a vector with a collection of 2D vectors inside it.
Syntax:
vector<vector<vector<int>>> v;
Example:
1 D vector -> { 1 , 2, 3 }
2 D vector -> { { 1,2,3 } , {4,5,6} }
3 D vector -> { { { 1,2,3 } , {4,5,6} } , { { 11,12,13 } , {14,15,16} } , { { 21,22,23 } , {24,25,26} } }
Below is the code of the example:
C++
#include <iostream>
#include <vector>
using namespace std;
int main()
{
// 1D Array
vector<int> a = { 1, 2, 3 };
cout<<"1D vector\n";
for (int i = 0; i < a.size(); i++) {
cout << a[i] << " ";
}
// 2D Array
vector<vector<int> > b = { { 1, 2, 3 }, { 4, 5, 6 } };
cout<<"\n\n2D vector\n";
for (int i = 0; i < b.size(); i++) {
for (int j = 0; j < b[0].size(); j++) {
cout << b[i][j] << " ";
}
cout << endl;
}
// 3D Array
vector<vector<vector<int> > > c = {
{ { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 9 } },
{ { 11, 12, 13 }, { 14, 15, 16 }, { 17, 18, 19 } },
{ { 21, 22, 23 }, { 24, 25, 26 }, { 27, 28, 29 } }
};
cout<<"\n\n3D vector\n";
cout << "[\n";
for (int i = 0; i < c.size(); i++) {
for (int j = 0; j < c[0].size(); j++) {
cout << " [ ";
for (int k = 0; k < c[0][0].size(); k++) {
cout << c[i][j][k] << " ";
}
cout << "]";
}
cout << endl;
}
cout << "]";
return 0;
}
Output1D vector
1 2 3
2D vector
1 2 3
4 5 6
3D vector
[
[ 1 2 3 ] [ 4 5 6 ] [ 7 8 9 ]
[ 11 12 13 ] [ 14 15 16 ] [ 17 18 19 ]
[ 21 22 23 ] [ 24 25 26 ] [ 27 28 29 ]
]
Copying vector elements in a new vector
It is the method where we can insert the values of the existing vector into the newly created vector during Initialisation.
Syntax:
vector<vector<vector<int>>> v2(v1.begin(),v2.end());
Example:
vector<vector<vector<int>>> v1={ { { 1, 2 }, { 3, 4 } },
{ { 5, 6 }, { 7, 8 } } }; // 3D vector original
vector<vector<vector<int>>> v2; // ( Copy elements of v1 inside v2 )
Code:
C++
#include <bits/stdc++.h>
using namespace std;
// function to display vector
void display(vector<vector<vector<int> > >& v)
{
for (int i = 0; i < v.size(); i++) {
cout << "i : " << i << endl;
for (int j = 0; j < v[i].size(); j++) {
for (int k = 0; k < v[i][j].size(); k++)
cout << v[i][j][k] << " ";
cout << endl;
}
cout << endl;
}
}
int main()
{
vector<vector<vector<int> > > v
= { { { 1, 2 }, { 3, 4 } },
{ { 5, 6 }, { 7, 8 } } };
// initializing vect using v
vector<vector<vector<int> > > vect(v.begin(), v.end());
display(vect);
}
Outputi : 0
1 2
3 4
i : 1
5 6
7 8
Time Complexity: O(n)
Here n is the number of elements in the original vector.
Auxiliary Space: O(n)
Copying vector elements using copy function in C++ STL
It is the method where we can insert the values of the existing vector into the newly created vector using copy() function in C++.
Syntax:
copy(first_iterator, last_iterator, back_inserter())
Example:
vector<vector<vector<int> > > v = { { { 1, 2 }, { 3, 4 } }, { { 5, 6 }, { 7, 8 } } }; // Original 3-D vector
copy(v.begin(), v.end(), back_inserter(vect)); // Copying vector elements to another vector by using copy() function
Code:
C++
#include <bits/stdc++.h>
using namespace std;
// function to display vector
void display(vector<vector<vector<int> > >& v)
{
for (int i = 0; i < v.size(); i++) {
cout << "i : " << i << endl;
for (int j = 0; j < v[i].size(); j++) {
for (int k = 0; k < v[i][j].size(); k++)
cout << v[i][j][k] << " ";
cout << endl;
}
cout << endl;
}
}
int main()
{
vector<vector<vector<int> > > v
= { { { 1, 2 }, { 3, 4 } },
{ { 5, 6 }, { 7, 8 } } };
// initializing vect
vector<vector<vector<int> > > vect;
// Copying vector by copy function
copy(v.begin(), v.end(), back_inserter(vect));
display(vect);
}
Outputi : 0
1 2
3 4
i : 1
5 6
7 8
Time Complexity: O(n)
Here n is the number of elements in the original vector.
Auxiliary Space: O(n)
Similar Reads
C++ Programming Language C++ is a computer programming language developed by Bjarne Stroustrup as an extension of the C language. It is known for is fast speed, low level memory management and is often taught as first programming language. It provides:Hands-on application of different programming concepts.Similar syntax to
5 min read
Non-linear Components In electrical circuits, Non-linear Components are electronic devices that need an external power source to operate actively. Non-Linear Components are those that are changed with respect to the voltage and current. Elements that do not follow ohm's law are called Non-linear Components. Non-linear Co
11 min read
Object Oriented Programming in C++ Object Oriented Programming - As the name suggests uses objects in programming. Object-oriented programming aims to implement real-world entities like inheritance, hiding, polymorphism, etc. in programming. The main aim of OOP is to bind together the data and the functions that operate on them so th
5 min read
Spring Boot Tutorial Spring Boot is a Java framework that makes it easier to create and run Java applications. It simplifies the configuration and setup process, allowing developers to focus more on writing code for their applications. This Spring Boot Tutorial is a comprehensive guide that covers both basic and advance
10 min read
Class Diagram | Unified Modeling Language (UML) A UML class diagram is a visual tool that represents the structure of a system by showing its classes, attributes, methods, and the relationships between them. It helps everyone involved in a projectâlike developers and designersâunderstand how the system is organized and how its components interact
12 min read
Steady State Response In this article, we are going to discuss the steady-state response. We will see what is steady state response in Time domain analysis. We will then discuss some of the standard test signals used in finding the response of a response. We also discuss the first-order response for different signals. We
9 min read
Backpropagation in Neural Network Back Propagation is also known as "Backward Propagation of Errors" is a method used to train neural network . Its goal is to reduce the difference between the modelâs predicted output and the actual output by adjusting the weights and biases in the network.It works iteratively to adjust weights and
9 min read
Inheritance in C++ The capability of a class to derive properties and characteristics from another class is called Inheritance. Inheritance is one of the most important features of Object-Oriented Programming in C++. In this article, we will learn about inheritance in C++, its modes and types along with the informatio
10 min read
Polymorphism in Java Polymorphism in Java is one of the core concepts in object-oriented programming (OOP) that allows objects to behave differently based on their specific class type. The word polymorphism means having many forms, and it comes from the Greek words poly (many) and morph (forms), this means one entity ca
7 min read
Decorators in Python In Python, decorators are a powerful and flexible way to modify or extend the behavior of functions or methods, without changing their actual code. A decorator is essentially a function that takes another function as an argument and returns a new function with enhanced functionality. Decorators are
10 min read