c++ vector

在做leetcode时总是用到各种容器,总是忘记个别的细节,这里试着以需要的功能为点,总结一下各种容器。

 vector 可增长的数组

初始化:

1. 空的容器

1
vector<int> vec;

2. 10个值初始化的元素

vector<int> vec (10);// int 类型会被初始化为 0;

3.10个指定值的元素;

vector<int> vec (53) ; //{3,3,3,3,3}

vector<int> vec ={1,2,3,4,5} ;

4.拷贝初始化:

vector <int> v2 (v1);

p1=v1.begin();
p2=v1.end();
vector<int> v2(p1,p2);

 

添加删除元素:

复制代码
//最后插入
vec.push_back(t);
//插入到迭代器p指向的元素之前
vec.insert(p,t);

//删除最后元素
vec.pop_back();
//删除p指向的元素,返回指向下一个元素的it
vec.erase(p);
复制代码

使用迭代器:

迭代器的范围是左闭右开的

vector<int>::iterator iter;

c.begin() ;
c.end();

//c开头的返回const 类型迭代器,当不需要写操作时,应该使用 c开头的方法
c.cbegin();
c.cend();

访问元素:

1.使用迭代器访问元素

*p = t;

2.front与 back成员

  front()返回头元素的引用,back()返回最后一个元素的引用;

  注意应该检查容器是否为空,对空容器使用front back会发生严重错误。

3.使用下标

 

posted @   失败者_ant  阅读(76)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示