插入和删除
函数原型:
两端插入操作:
指定位置操作:
代码语言:javascript复制#include<iostream>
using namespace std;
#include<deque>
//deque的插入与删除操作
void p(const deque<int>& d)
{
for (deque<int>::const_iterator it = d.begin(); it != d.end(); it )
{
//*it = 100; 加了const关键字后,就无法对数据进行修改
cout << *it << " ";
}
cout << endl;
}
void realApply()
{
deque<int>d1;
//1.尾插
d1.push_back(5);
d1.push_back(2);
d1.push_back(0);
cout << "尾插:";
p(d1);
//2.头插
d1.push_front(1);
d1.push_front(2);
d1.push_front(5);
cout << "头插:";
p(d1);
//3.尾删
d1.pop_back();
cout << "尾删:";
p(d1);
//4.头删
d1.pop_front();
cout << "头删:";
p(d1);
//5.在pos位置插入elem元素的拷贝,返回新元素的值
int pos=*d1.insert(d1.begin(),5); //第一个参数必须填迭代器,第二个参数填插入的元素
cout << "指定位置插入新元素后: ";
p(d1);
cout << "新元素的值:" << pos << endl;
//6.在pos位置插入n个elen元素,无返回值
d1.insert(d1.begin(), 3, 520);
cout << "指定位置插入N个新元素之后:";
p(d1);
//7.在指定位置插入区间的数据,无返回值
d1.insert(d1.begin(), d1.begin(), d1.end()-5); //这里的end-计算方法和vector相反,deque这里是从末尾算起,vector从开头算起
cout << "指定位置插入某段区间的值后: ";
p(d1);
//8.删除pos位置的数据
d1.erase(d1.begin());
cout << "删除pos位置的数据后: ";
p(d1);
//9.删除某段区间数据
d1.erase(d1.begin(), d1.end()-5);
cout << "删除某段区间数据后: ";
p(d1);
//10.清空所有数据
d1.clear();
cout << "清空所有数据后: ";
p(d1);
}
int main()
{
realApply();
system("pause");
return 0;
}