1.使用push_back

除了array和forward_list外,每个顺序容器都支持push_back,意为在尾部添加元素

2.使用push_front

list、forward_list和deque支持push_front,也就是插入到容器头部

3.特定位置添加元素

forward_list中提供了特殊版本的insert成员,下面介绍的是其他容器:第一个参数是迭代器,第二个是插入元素

vector<int>a = { 4,5,9 };
a.insert(a.begin(), 7);			//此操作类似push_front

4.插入范围内元素

第一个参数是迭代器,第二个是插入的个数,第三个是插入的元素

vector<int>a = { 4,5,9 };
a.insert(a.begin(), 3, 7);        //开头插入三个7

第一个参数是迭代器,第二三个参数是待插入的容器的迭代器。如果给a传递一对迭代器,那么那一对迭代器不能是它本身

vector<int>a = { 4,5,9 }, b = { 4,6,7 };
a.insert(a.begin(), b.begin(), b.end());

5.insert的返回值

insert返回的迭代器恰好指向新元素(如果插入范围内返回第一个元素的迭代器),因此有以下代码

int num;
vector<int>a = { 4,5,9 };
auto it = a.begin();
while (cin >> num)
	it = a.insert(it, num);

6.c++11中引入了三个新成员:emplace_front、emplace、emplace_back他们的操作类似于push_front、insert、push_back但是它们的操作是构造而不是拷贝元素。我们使用push、insert时,我们将元素类型的对象传递给它们,这些对象被拷贝到容器中;而emplace则是将参数传递给元素类型的构造函数,emplace在容器管理的内存空间直接构造元素

vector<int>a = { 4,5,9 };
a.emplace_back(7);
a.emplace(a.begin(), 2, 5);

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐