deque容器04之插入和删除

2021-03-02 17:02:25 浏览数 (1)

插入和删除

函数原型:

两端插入操作:

指定位置操作:

代码语言: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;
}

0 人点赞