logo

vector insert() Funció en C++ STL

std::vector::insert() és una funció integrada en C++ STL que insereix nous elements abans de l'element a la posició especificada, augmentant efectivament la mida del contenidor pel nombre d'elements inserits.

Complexitat temporal - Lineal, O(N)



La funció d'inserció està sobrecarregada per funcionar en diversos casos, que són els següents:

  1. Insereix un element a l'índex donat.
  2. Insereix un element diverses vegades.
  3. Insereix un rang d'elements a l'índex donat.

1. Inseriu un element a l'índex donat

Sintaxi de insert() en Vector

vector_name.insert (position, val);>

Paràmetres

La funció accepta dos paràmetres especificats a continuació:

  • posició Especifica l'iterador que apunta a la posició on s'ha de fer la inserció.
  • val Especifica el valor a inserir.

Exemple d'inserció () en vector

C++








// C++ program to illustrate the function of> // vector_name.insert(position,val)> #include> using> namespace> std;> > int> main()> {> > >// Initialising the vector> >vector<>int>>nom_vector{ 1, 2, 3, 4, 5};>>> >// Printing out the original vector> >cout <<>'Original vector : '>;> >for> (>auto> x : vector_name)> >cout << x <<>' '>;> >cout <<>' '>;> > >// Inserting the value 100 at position 3(0-based> >// indexing) in the vector> >vector_name.insert(vector_name.begin() + 3, 100);> > >// Printing the modified vector> >cout <<>'Vector after inserting 100 at position 3 : '>;> >for> (>auto> x : vector_name)> >cout << x <<>' '>;> >cout <<>' '>;> > >// Inserting the value 500 at position 1(0-based> >// indexing) in the vector> >vector_name.insert(vector_name.begin() + 1, 500);> > >// Printing the modified vector> >cout <<>'Vector after inserting 500 at position 1 : '>;> >for> (>auto> x : vector_name)> >cout << x <<>' '>;> >return> 0;> }> > // This code is contributed by Abhijeet Kumar(abhijeet19403)>

llista ordenar per java
>

>

Sortida

Original vector : 1 2 3 4 5 Vector after inserting 100 at position 3 : 1 2 3 100 4 5 Vector after inserting 500 at position 1 : 1 500 2 3 100 4 5>

2. Inseriu diversos elements a l'índex donat

Sintaxi de insert() en Vector

vector_name.insert(position, size, val)>

Paràmetres

La funció accepta tres paràmetres especificats a continuació:

  • posició Especifica l'iterador que apunta a la posició on s'ha de fer la inserció.
  • mida Especifica el nombre de vegades que s'ha d'inserir un val a la posició especificada.
  • val Especifica el valor a inserir.

Exemple d'inserció () a Vector

C++




// C++ program to illustrate the function of> // vector_name.insert(position,size,val)> #include> using> namespace> std;> > int> main()> {> > >// Initialising the vector> >vector<>int>>nom_vector{ 1, 2, 3, 4, 5};>>> >// Printing out the original vector> >cout <<>'Original vector : '>;> >for> (>auto> x : vector_name)> >cout << x <<>' '>;> >cout << endl;> > >// Inserting the value 100, 4 times starting at position> >// 3> >vector_name.insert(vector_name.begin() + 3, 4, 100);> > >// Printing the modified vector> >cout <<>'Vector after inserting 100, 4 times, starting '> >'at position 3 : '>;> >for> (>auto> x : vector_name)> >cout << x <<>' '>;> >return> 0;> }> > // This code contributed by Harsh Singh (hsnooob)>

>

el meu flixer

>

Sortida

Original vector : 1 2 3 4 5 Vector after inserting 100, 4 times, starting at position 3 : 1 2 3 100 100 100 100 4 5>

3. Inseriu el rang d'elements a l'índex donat

Sintaxi de Vector insert()

vector_name.insert(position, iterator1, iterator2)>

Paràmetres

La funció accepta tres paràmetres especificats a continuació:

  • posició Especifica la posició en què s'ha de fer la inserció al vector.
  • iterador 1 Especifica la posició inicial des de la qual s'han d'inserir els elements
  • iterador 2 Especifica la posició final fins a quins elements s'han d'inserir

Exemple d'inserció vectorial ()

C++




// C++ program to illustrate the function of> // vector_name.insert(position,itr1,itr2)> #include> using> namespace> std;> > int> main()> {> > >// Initialising the vector> >vector<>int>>original{1, 2, 3, 4, 5};>>> >vector<>int>>temp{ 2, 5, 9, 0, 3, 10};>>> >// Printing out the original vector> >cout <<>'Original vector : '>;> >for> (>auto> x : original)> >cout << x <<>' '>;> >cout << endl;> > >// Inserting the portion of temp vector in original> >// vector temp.begin()+3 is starting iterator of vector> >// to be copied temp.begin()+5 is ending iterator of> >// vector to be copied> >original.insert(original.begin() + 3, temp.begin() + 2,> >temp.begin() + 5);> > >// Printing the modified vector> >cout <<>'Vector after Inserting the portion of temp '> >'vector in original vector : '>;> >for> (>auto> x : original)> >cout << x <<>' '>;> >return> 0;> }> > // This code contributed by Harsh Singh (hsnooob)>

>

>

Sortida

Original vector : 1 2 3 4 5 Vector after Inserting the portion of temp vector in original vector : 1 2 3 9 0 3 4 5>