c++顺序容器添加元素
1.使用push_back除了array和forward_list外,每个顺序容器都支持push_back,意为在尾部添加元素2.使用push_frontlist、forward_list和deque支持push_front,也就是插入到容器头部3.特定位置添加元素forward_list中提供了特殊版本的insert成员,下面介绍的是其他容器:第一个参数是迭代器,第二个是插入元素vector&l
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);
更多推荐
所有评论(0)