目录
- C++vector 用法整理
- 1.头文件
- 2.vector初始化
- 3.vector对象的重要操作
- 1.赋值(assign)
- 2.返回元素值
- 3.清空、判断是否为空
- 4.删除
- 5.插入
- 6.返回vector的现存元素个数、共可容纳个数
- 7.调整元素个数(这个好牛)
- 8.整体*换
- 9.向量的比较操作
- 10.重要算法
- 4.一些误区
- 总结
C++vector 用法整理
1.头文件
#include<iostream>//容器
#include<vector> //算法
#include<iterator>//迭代器
一个代码示例

#include<iostream>//容器
#include<vector> //算法
#include<iterator>//迭代器
using namespace std;
int main(int argc, const char* argv[])
{
const int SIZE = 6;
int array[SIZE] = {1,2,3,4,5,6};
vector<int> v(array,array+SIZE);
cout<<"First element:"<<v.front()<<"\n Last element"<<v.back()<<endl;
}
2.vector初始化
定义十个整形元素的向量(其中初值不确定)
vector<int> a(10);
每个元素初值为1;
vector<int> a(10,1);
类似于深拷贝的整体赋值方式
vector<char> a(b);
vector<char> a(b.begin(),b.begin+3);//(a的值为0~2个元素)
用数组赋初值(和上面一个有点相似)
vector<int> a(b, b+7);
3.vector对象的重要操作
1.赋值(assign)
a.assign(b.begin(),b.begin()+3); //注意!此处,将b 0~2个元素构成的向量赋值给a!与上面不同!
a.assign(4,2);// 与vector<int> a(10,1);结果相同
2.返回元素值
//返回最后一个元素
a.back();
//返回第一个元素
a.front();
//数组返回式
a[i];
3.清空、判断是否为空
a.clear();
a.empty();
4.删除
//删除最后一个元素
a.pop_back();
//删除一块元素
a.erase(a.begin(),a.begin()+3);
5.插入
//在最后一个向量后插入一个元素
a.push_back(5);
// 插入一段元素(从第一个元素算起,插入3个数,值都为5)
a.insert(a.begin(), 3, 5);
//用数组插入一段元素(在a的第一个元素的位置插入b的第3个元素到第5个元素)
a.insert(a.begin(), b+1,b+6);
//从现有向量中选择元素向向量中添加
int a[6] = {1, 2, 3, 4, 5, 6};
vector<int> b;
wector<int> c(a, a+4);
for(vector<int>::iterator it = c.begin(); it<c.end():it++)
{
b.push_back(*it);
}
//从文件读取元素向向量中添加
ifstream in("data.txt");
vector<int> a;
for(int i;in>>i)
{
a.push_back(i);
}
6.返回vector的现存元素个数、共可容纳个数
a.size();
a.c apacity();
7.调整元素个数(这个好牛)
//将元素个数调整至10,多删少补,补的值随机
a.resize(10);
//将元素个数调整至10,多删少补,补的值为2
a.resize(10,2);
//大容量扩充(不补充值)
a.reserve(100);
8.整体*换
a.swap(b);
9.向量的比较操作
a==b;
//还有 != >= <= > <
10.重要算法
//从小到大排列
sort(a.begin(), a.end());
//倒置但不排列
reverse(a.begin(),a.end());
//元素复制
copy(a.begin(),a.end(),b.begin());
//从某一区块中查找元素值,返回位置
find(a.begin(),a.end(),10);
4.一些误区
下标只能获取已存在的元素,不能进行赋值操作
//错误示例
vector<int> a;
for(int i = 0;i<10;i++)
a[i] = i;
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注的更多内容!
相关推荐:
为什么seo推广那么多,seo推广难吗 ,东莞ai听译平台
AI人工智能:开发与应用的必备软件推荐
SEO部:开启数字化营销新纪元的幕后英雄,株洲营销推广是什么公司
SEO而且:打造高效网站流量增长的秘密武器,滨江网站推广营销
SEO这种营销方式,改变你网站流量的秘密武器,佛山网站设计建设
ChatGPT破解:人工智能的无限潜力与破解秘笈,意识变ai
seo适用于什么领域,seo适用于什么领域中 ,ai智能翻译写作机器人v1.0
seo软件工具,seo软件是什么 ,AI妆容
优排软件:高效管理新天地,轻松提升工作效率,长葛外贸网站建设
seo适合什么行业,seo适合的行业 ,在ai如何矢量化
SEO自从上线后的演变与未来发展趋势,拼多多增加关键词排名
ChatGPT您的应用遇到问题,无法正常启动?如何解决并重新体验智能助手的魅力!,男头ai关键词
ChatGPT页面无法翻阅?带你深度了解背后的原因与解决方案,pdf怎么转换ai文字
ChatGPT无法打开?这些解决办法让你重新畅享智能对话!,北大写作ai
OpenAI无法验证支付方式?解决方案与常见问题解析,你好月光ai
未来智能:AI智能人工软件引领数字化变革
为什么“蜘蛛弛查询”能成为提升网站排名的秘密武器?,惠州网站推广v1戈seo24
亚马逊seo是什么公司的,“亚马逊” ,ai玩底特律
优化标题:如何让你的文章更具吸引力与点击力,整站网站优化解决方案
ChatGPT无服务:如何突破限制,未来人工智能的新可能,ai绘制装饰画
用AI写一篇文章,如何提升你的写作效率与创意
seo需要什么部门,seo主要干什么 ,ai接入仪器
ChatGPT的超链接点不开?解决方法一网打尽!,情感ai写作指令是什么
SEO网:让你的数字营销更加精准高效,开启网络引流新时代,丰县互联网网站推广优势
AI代写文章:高效创作的新风尚
SEO才能:提升网站排名,突破网络营销的核心竞争力,南宁本地seo营销公司
SEO提高:如何通过精准优化让网站流量翻倍,优化排名seo加盟费用
ChatGPT显示503:如何应对AI服务不可用的困境?,ai宝贝宝贝
AI免费试用不需要登录:体验智能科技的魅力,轻松开启未来,华为ai身材
ChatGPT登录界面都不显示了?可能是这些原因导致的!,上海小学ai智能课
SEO要求:如何优化网站提升搜索引擎排名,助力企业获取更多流量,鹤山区网站运营推广
WPS改写-轻松提升文档创作效率的秘密武器,推广网站的优势
优方法-高效生活与工作的秘密武器,钻石营销推广方案
亚马逊的seo是什么阿,亚马逊seo项目 ,中考用ai写作会判0分吗
seo链接锚是什么,什么是锚链接,如何设置锚链接 ,保山智能AI
为什么选择收录网站是企业在线营销的必备策略,全网营销与推广
ChatGPT画布打不开?如何解决这一常见问题?,Ai怎么储存为Ai格式在桌面
SEO优化:让你的网站在竞争中脱颖而出,临沧seo代理
摘要AI生成:高效工作的新时代利器
OpenAIGPTChatSoraOpenAIChatGPT服务在中断数小时后已恢复,ai视图线稿
seo规范是什么,seo行业标准 ,啊龙ai音乐
常用AI工具,高效智能生活
ChatGPT安装包Windows版-让智能助手触手可得,q和ai
人工AI软件的未来:智能时代的创新驱动力
SEO分类:从基础到进阶,全面解析SEO优化的关键要素,新建设网站排名
SEO北京:数字时代,企业成功的关键,湖南网站建设湖南岚鸿
ChatGPT错误处理与异常情况解决方法:让你的AI助手更加智能与可靠,智能ai鼠标ai智能语音
SEO基础知识解析:如何提升网站排名,助力企业成长,毕节企业建设网站
ChatGPT美区要梯子吗?轻松畅享全球智能聊天体验,ai音位
AI人工智能:改变未来的科技革命