vector

注意:vector是一个实现顺序表的类模板 ,在构造一个对象时一定要显示实例化。且使用vector时要包含头文件:#include<vector>。

显示实例化:

一.常用接口

构造函数

传参的几种方式:

①.全缺省。

②.给定插入个数以及要插入的内容。(全顺序表都是一个重复字符)。

eg:

输出的是一个全为1的数组

③.拷贝构造。

遍历

1.[]

和string一样,vector重载了[],可用于元素的遍历。

2.迭代器(iterator)

reserve

对比string的reserve而言,没有历史包袱,所以 n < capacity时,reserve不会对_capacity和_size产生影响,不会缩容。

resize

改变容器元素个数(即size大小)。

首个参数n是目标size,第二个参数是新增元素的填充值。如果n < size,就删除vector中数据,直至size为n。如果n > size,就进行扩容,直至size为n,且新增元素用第二个参数给的数填充。

insert

在指定位置前插入某个值,首个参数不支持下标,但支持迭代器begin(),end()。所以想要在第n个位置前插入数据,就可以用begin() + n

erase

依旧支持迭代器不支持下标。可删除某个位置的值,也可以删除某个区间的值(不常用)。

支持比大小

不支持流插入流提取

vector的打印具有很多不确定性。

要实现流插入直接用for循环配[]。

实现流提取可以用构造函数配for循环

二.二维数组

实现

会实例化两个类,先实例化vector<int>,再实例化vector<vector<int>>。vector<int>代表行空间,vector<vector<int>>代表列空间。

访问

依旧可以使用重载的[]对用vector实现的二维数组里的元素进行访问:

第一个[]访问vector<vector<int>>中的元素,返回vector<int>的引用,确认好行 。第二个[]访问这个vector<int>中的元素,确认好列,返回int的引用,也就是访问的目标元素。

遍历

相关推荐
wljy110 小时前
第十三届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯·stl
小此方1 天前
Re:思考·重建·记录 现代C++ C++11篇 (一) 列表初始化&Initializer_List
开发语言·c++·stl·c++11·现代c++
小此方7 天前
Re:从零开始的 C++ STL篇(十)map/set使用精讲:常见问题与典型用法(上)
开发语言·数据结构·c++·算法·stl
小此方7 天前
Re:从零开始的 C++ STL篇(九)AVL树太“较真”,红黑树更“现实”:一文讲透工程中的平衡之道
开发语言·数据结构·c++·算法·stl
进击的荆棘7 天前
C++起始之路——二叉搜索树
数据结构·c++·stl
xiaoye-duck8 天前
【C++:unordered_set和unordered_map】 深度解析:使用、差异、性能与场景选择
开发语言·c++·stl
羊小蜜.8 天前
C++17: map & multimap—— 键值映射容器
开发语言·c++·stl
qq_283720059 天前
C++ 基础:STL 原理介绍 + 实用技巧
c++·stl·c·模板库
是娇娇公主~10 天前
C++ std::map 与 std::unordered_map
c++·stl
是娇娇公主~10 天前
C++迭代器详解
开发语言·c++·stl