deque::insert
描述 (Description)
C ++函数std::deque::insert()通过在容器中插入新元素来扩展deque。 如果重新分配发生,则内部分配器将满足此容器的存储要求。
声明 (Declaration)
以下是std :: deque :: insert()函数形式std :: deque标头的声明。
C++11
iterator insert (const_iterator position, value_type&& val);
参数 (Parameters)
position - deque中要插入新元素的索引。
value - 要分配给新插入元素的值。
返回值
返回指向新插入元素的迭代器。
异常 (Exceptions)
如果重新分配失败,则抛出bad_alloc异常。
时间复杂
线性即O(n)
例子 (Example)
以下示例显示了std :: deque :: insert()函数的用法。
#include <iostream>
#include <deque>
using namespace std;
int main(void) {
deque<int> d1 = {1, 2, 3, 4, 5};
deque<int> d2;
for (int i = 0; i < d1.size(); ++i)
d2.insert(d2.begin() + i, move(*(d1.begin() + i)));
cout << "Content of deque are" << endl;
for (auto it = d2.begin(); it != d2.end(); ++it)
cout << *it << endl;
return 0;
}
让我们编译并运行上面的程序,这将产生以下结果 -
Content of deque are
1
2
3
4
5