C++ VECTOR容器
Vector:一个容器,可以构建链表等数据结构
#include<vector> using namespace std;
创建一个vector对象
vector <int> I1; //一个int型的空的vector对象I1 vector <int> I2(500); //包含500个int类型数据的vector对象I2 vector <int> I3(500,1);//把500个数据都赋值1 vector <int> A(B);//把B整体复制到A中 vector <int> A(B.begin(),B.begin()+4);//把B中开始的4个元素(0~3)复制到A
销毁
I.~vector <int> ();
PS:这里的I是之前建立的vector对象名
插入元素:
1、用push_back()在vector尾插入,而不用A[i]=a这种的赋值语句
//添加单个元素 I.push_back(a); //添加多个元素 B[6]={0,1,2,3,4,5}; for(int i=0;i<4;i++) I.push_back(B[i]); //从已有的向量中选择添加 //B是一个int型的vector对象 for(vector <int> ::iterator it=B.begin();it<B.end();it++) I.push_back(*it); //误区 不能用数组下标的方式添加元素,只能用这种方式访问已经存在的元素 for(int i=0;i<6;i++) I[i]=i;//错误 cout<<I[0];//这种是允许的,相当于把[]进行了运算符重载
注意:
如果用vector <int> I(500);这种形式创建了vector对象,那么在push_back()后,push_back的数据在501个
如果想从第一个开始添加,应该采用 vector <int> I;的形式创建
2、用insert在任意位置插入
I.insert(pos,elem); //pos位置插入一个元素elem
I.insert(pos,n,elem) ;//pos位置插入n个元素elem
I.insert(pos,begin,end);//pos位置插入从begin到end(不包含end)的元素
注意这个pos只能是I.begin()+m这种类似形式,而不能单写一个数字
begin与end也是 B.begin()和B.begin()+3这样类似的形式,表示从B.begin()开始的连续三个元素
读取元素
//用下标的方式,同普通数组 //这种方式不安全,常用下一种方法 cout<<I[2]; //at函数 cout<<I.at(2) //I.at(i)等价于I[i],只是更加安全,还会在越界时发出警告
迭代
//如何对一个vector对象实现类似下边的操作呢? //for(int i=0;i<N;i++) // cout<<I[i]; //这涉及到vector的迭代方式 //迭代器的类型写为 vector <int> :: iterator vector <int > B(500,1); for(vector <int>::iterator it=B.begin();it!=B.end();it++) //最后一个B.end()是不能取等号的,相当于大小为6的数组不能取下标为6 cout<<*it; //星号*不能少
删除元素
I.clear(); 删除所有元素
I.pop_back();删除最后一个元素
其他的函数可以参考:
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性