C++——Vector容器

本文深入探讨了C++标准模板库中的Vector容器,详细解释了Vector如何通过动态数组管理元素,支持随机存取和高效地在尾部添加或移除元素。同时,文章也提到了在中间插入或删除元素时的效率问题,并提供了Vector对象的创建和使用的实例。
摘要由CSDN通过智能技术生成

vector是将元素置于一个动态数组中加以管理的容器。

vector可以随机存取元素(支持索引值直接存取, 用[]操作符或at()方法)。

vector尾部添加或移除元素非常快速。但是在中部或头部插入元素或移除元素比较费时,因为vector在内存中是一块连续的内存空间,类似于线性表的形式,当在中间插入或删除时,其他元素需要移动。

vector采用模板类实现,vector对象的默认构造形式
vector<T> vecT; 

vector<int> vecInt;        	//一个存放int的vector容器。
vector<float> vecFloat;     	//一个存放float的vector容器。
vector<string> vecString;   	//一个存放string的vector容器。
...				    //尖括号内还可以设置指针类型或自定义类型。
Class CA{};
vector<CA*> vecpCA;	  	//用于存放CA对象的指针的vector容器。
vector<CA> vecCA;     	//用于存放CA对象的vector容器。由于容器元素的存放是按值复制的方式进行的,所以此时CA必须提供CA的拷贝构造函数,以保证CA对象间拷贝正常。
//数组元素的 添加和删除
{
	vector<int> v1;

	cout << "length:" << v1.size() <<endl;
	v1.push_back(1);//在尾部插入一个元素,值为1
	v1.push_back(3);
	v1.push_back(5);
	cout << "length:" << v1.size() <<endl;

	cout << "头部元素" << v1.front() << endl;


	//修改 头部元素
	//函数返回值当左值 应该返回一个引用
	v1.front() = 11;//把头部元素修改为11
	v1.back() = 55;//把尾部元素修改为55

//遍历,读取尾部元素后删除该元素。直至该vector中没有元素
	while (v1.size() > 0)
	{
		cout <<"尾部元素" << v1.back() ; //获取尾部元素
		v1.pop_back(); //删除尾部元素
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值