deque::insert
Vloží prvek nebo počet prvků, nebo rozsahu prvků v deque na určené pozici.
iterator insert(
const_iterator Where,
const Type& Val
);
iterator insert(
const_iterator Where,
Type&& Val
);
void insert(
iterator Where,
size_type Count,
const Type& Val
);
template<class InputIterator>
void insert(
iterator Where,
InputIteratorFirst,
InputIteratorLast
);
iterator insert(
iterator Where,
initializer_list<Type> IList
);
Parametry
Parametr |
Popis |
Where |
Umístění v cílovém deque vloženy první prvek. |
Val |
Hodnota elementu bude vložen do deque. |
Count |
Počet prvků bude vložen do deque. |
First |
První prvek pozice v rozsahu prvků v argumentu deque ke kopírování. |
Last |
Pozice mimo rozsah prvků první prvek v deque argument ke kopírování. |
IList |
Initializer_list prvky, které chcete vložit. |
Vrácená hodnota
Vložit první dvě funkce vrátí iterace odkazující na pozici kde nový prvek byl vložen do deque.
Poznámky
Všechny operace vložení může být nákladné.
Kód
// deque_insert.cpp
// compile with: /EHsc
#include <deque>
#include <iostream>
#include <string>
int main()
{
using namespace std;
deque <int> c1, c2;
deque <int>::iterator Iter;
c1.push_back(10);
c1.push_back(20);
c1.push_back(30);
c2.push_back(40);
c2.push_back(50);
c2.push_back(60);
cout << "[ c1 = ";
for (auto c1_iter : c1)
cout << c1_iter << " ";
cout << "]" << endl;
Iter = c1.begin();
Iter++;
c1.insert(Iter, 100);
cout << "[ c1 = ";
for (auto c1_iter : c1)
cout << c1_iter << " ";
cout << "]" << endl;
Iter = c1.begin();
Iter++;
Iter++;
c1.insert(Iter, 2, 200);
cout << "[ c1 = ";
for (auto c1_iter : c1)
cout << c1_iter << " ";
cout << "]" << endl;
c1.insert(++c1.begin(), c2.begin(), --c2.end());
cout << "[ c1 = ";
for (auto c1_iter : c1)
cout << c1_iter << " ";
cout << "]" << endl;
// initialize a deque of strings by moving
deque < string > c3;
string str("a");
c3.insert(c3.begin(), move(str));
cout << "Moved first element: " << c3.front() << endl;
c1.insert(c1.end(), { 70, 80, 90 });
for (auto c1_iter : c1)
cout << c1_iter << " ";
cout << endl;
}// deque_insert.cpp
// compile with: /EHsc
#include <deque>
#include <iostream>
#include <string>
int main( )
{
using namespace std;
deque <int> c1, c2;
deque <int>::iterator Iter;
c1.push_back( 10 );
c1.push_back( 20 );
c1.push_back( 30 );
c2.push_back( 40 );
c2.push_back( 50 );
c2.push_back( 60 );
cout << "[ c1 = ";
for ( Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
cout << *Iter << " ";
cout << "]" << endl;
Iter = c1.begin( );
Iter++;
c1.insert( Iter, 100 );
cout << "[ c1 = ";
for ( Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
cout << *Iter << " ";
cout << "]" << endl;
Iter = c1.begin( );
Iter++;
Iter++;
c1.insert( Iter, 2, 200 );
cout << "[ c1 = ";
for ( Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
cout << *Iter << " ";
cout << "]" << endl;
c1.insert( ++c1.begin( ), c2.begin( ),--c2.end( ) );
cout << "[ c1 = ";
for ( Iter = c1.begin( ); Iter != c1.end( ); Iter++ )
cout << *Iter << " ";
cout << "]" << endl;
// initialize a deque of strings by moving
deque < string > c3;
string str("a");
c3.insert( c3.begin(), move( str ) );
cout << "Moved first element: " << c3.front( ) << endl;
}
Výsledek
[ c1 = 10 20 30 ]
[ c1 = 10 100 20 30 ]
[ c1 = 10 100 200 200 20 30 ]
[ c1 = 10 40 50 100 200 200 20 30 ]
Moved first element: a
10 40 50 100 200 200 20 30 70 80 90
Požadavky
Záhlaví: <deque>
Obor názvů: std