c++ vector用法详解
1. 定义:
向量(Vector)是一个封装了动态大小数组的顺序容器(Sequence Container)可以认为是一个动态数组,其中一个vector中的所有对象都必须是同一种类型的。
2. 构造函数:
2.1 一般情况
- vector vecName(); // 构造一个空vector,其中包含的对象为int类型
- vector vecName(3); // 构造一个空vector,其中包含的对象为int类型,大小为3
- vector vecName(3,value); // 构造一个空vector,其中包含的对象为int类型,大小为3,对象均为value
- vector vecName = { 1, 2, 3, 4 }; // 构造一个vector,初始值为[1,2,3,4]
- vector vecName(vecName2); // 构造一个vector,初始值为另一个vector类型的vecName2
2.2 将vec1的部分赋给vec2
- vector::const_iterator First = vec1.begin() + 1; // 找到开始迭代器
- vector::const_iterator Second = vec1.begin() + 4; // 找到结束迭代器
- vector vec2(First, Second); // 将值直接初始化到vec2(需要注意包括开头,但不包括结尾,即vec2只包含vec[1]到vec[3]的元素)
2.3 二维数组构造方法
- vector<vector > vecName(3); // 构造一个二维vector,其中一个维度为3
- vector<vector > vecName(3,vector(4)); // 构造一个3*4 的二维vector,其中默认值为0
- vector<vector > vecName(3, vector(4,1)); // 构造一个3*4 的二维vector,值均为1
- vector<vector > vecName = { {1, 2, 3}, {4, 5, 6} }; // 构造一个2*3 的二维vector,并赋值
3. 增加元素:
- vec1.push_back(x); // 在vec1的尾部添加一个元素x(注意:一般可以用emplace_back()代替,效率更高)
- vec1.insert(iterator iter, x); // 在vec1的迭代器iter指向元素前增加一个元素x
- vec1.insert(iterator iter, int n, x); // 在vec1的迭代器iter指向元素前增加n个元素x
- vec1.insert(iterator iter, const_iterator first,const_iterator last); // 在vec1的迭代器iter指向元素前插入另一个相同类型向量的[first,last)间的数据
4. 删除元素:
- vec1.pop_back(); // 删除在vec1的最后一个元素
- vec1.clear(); // 删除vec1中所有元素
- vec1.erase(iterator iter); // 删除vec1中迭代器指向元素
- vec1.erase(iterator first,iterator last); // 删除vec1中[first,last)中元素
5. 使用元素:
5.1 一般使用法
- vec1[1]; // 使用下标方式
- vec1.at(1); // 使用at方式
- vec1.front(); // 使用第一个元素
- vec1.back(); // 使用最后一个元素
5.2迭代器指针使用法:
- iterator begin(); // 返回向量头指针,指向第一个元素
vector<int>::iterator d = vec1.begin();
int d1 = *d;//vec1[0]
- iterator end(); // 返回向量尾指针,指向向量最后一个元素的下一个位置
vector<int>::iterator e = vec1.end() - 1;
int e1 = *e;//vec1[last]`
反向迭代器,是从后往前数的,即+1代表向前数一个元素
- reverse_iterator rbegin(); // 反向迭代器,指向最后一个元素
vector<int>::reverse_iterator f = vec1.rbegin();
int f1 = *f;//vec1[last]`
- reverse_iterator rend(); // 反向迭代器,指向第一个元素之前的位置,也就是vector[-1]
vector<int>::reverse_iterator g = vec1.rend() - 1;
int g1 = *g;//vec1[0]
6. 判断是否为空:
- bool empty() const:判断向量是否为空,若为空,则向量中无元素
vector<int> vec1 = { 1, 2, 3, 4, 5 };
bool i = vec1.empty();//输出:false
vector<int> vec2 = { };
bool j = vec2.empty();//输出:true
7. 大小函数:
- unsigned int length = vec1.size()//vec1所含元素的个数
8. 使用时的注意事项:
8.1 头文件及其命名空间
#include<vector>
using namespace std;
8.2 Vector 作为函数的返回值时,
方法一:vector<int> fun1(int num);
(不推荐)
方法二:bool fun1(int num, vector<int> $&$vec);
(推荐)
8.3 将vec2中的内容追加到vec1的后面:
vec1.insert(vec1.end(), vec2.begin(), vec2.end());
8.4 最大最小元素及其索引:
#include<algorithm>
vector<double>::iterator biggest = max_element(begin(vec1), end(vec1));
double biggestValue = *biggest;//最大值
int biggestIndex = distance(begin(begin(vec1), biggest);//最大值索引
vector<double>::iterator smallest = min_element(begin(vec1), end(vec1));
double smallestValue = *smallest;//最大值
int smallestIndex = distance(begin(begin(vec1), smallest);//最大值索引
c++ vector用法详解的更多相关文章
- 【C++】vector用法详解
转自:https://blog.csdn.net/fanyun_01/article/details/56842637#commentBox 一.简介 C++ vector类为内置数组提供了一种替代表 ...
- c++中vector的用法详解
c++中vector的用法详解 vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间 ...
- STL vector常见用法详解
<算法笔记>中摘取 vector常见用法详解 1. vector的定义 vector<typename> name; //typename可以是任何基本类型,例如int, do ...
- 7-set用法详解
C++中set用法详解 转载 http://blog.csdn.net/yas12345678/article/details/52601454 C++ / set 更详细见:http://www.c ...
- STL priority_queue 常见用法详解
<算法笔记>学习笔记 priority_queue 常见用法详解 //priority_queue又称优先队列,其底层时用堆来实现的. //在优先队列中,队首元素一定是当前队列中优先级最高 ...
- STL string 常见用法详解
string 常见用法详解 1. string 的定义 //定义string的方式跟基本数据类型相同,只需要在string后跟上变量名即可 string str; //如果要初始化,可以直接给stri ...
- STL set 常见用法详解
<算法笔记>学习笔记 set 常见用法详解 set是一个内部自动有序且不含重复元素的容器 1. set 的定义 //单独定义一个set set<typename> name: ...
- 2.3 C++STL vector容器详解
文章目录 2.3.1 引入 2.3.2 代码实例 2.3.3 运行结果 总结 2.3.1 引入 vector 容器 动态数组 可变数组 vector容器 单口容器(尾部操作效率高) vector动态增 ...
- C#中string.format用法详解
C#中string.format用法详解 本文实例总结了C#中string.format用法.分享给大家供大家参考.具体分析如下: String.Format 方法的几种定义: String.Form ...
随机推荐
- 解决了一个java服务线程退出的问题
问题背景 早上才上班,测试就提了一个问题:"昨天所有批量任务都没有跑".我看了一下任务监控页面,任务是有生成的,但却一直在等待调度状态.初步怀疑是我们的调度服务问题,于是上去查 ...
- Python+Selenium学习笔记19 - 自动发送邮件
发送简单的邮件 用一个QQ邮箱发送到另一个QQ邮件. 首先设置QQ邮箱,邮箱设置 -> 账号 开启SMTP服务,点击开启按钮,按提示进行操作,需要1毛钱的短信费.开启后如下所示 1 # codi ...
- 牛客网论坛最具争议的Java面试成神笔记,牛客网下载量已突破十万
程序员内部一直流传这一句话: 面试看牛客 刷题看力扣 牛客网作为国内最牛的程序员面试网站,一直在程序员内部颇负盛名,其中用户更是卧虎藏龙! 有国内一线大厂的企业招聘 还有一些低调的互联网大牛实力就和天 ...
- 【Java面试真题】剑指Offer53.2——0~n-1中缺失的数字(异或、二分两种解法)
[Java实现]剑指Offer53.2--0~n-1中缺失的数字:面试真题,两种思路分享 前面有另一道面试题[Java实现]剑指offer53.1--在排序数组中查找数字(LeetCode34:在排序 ...
- Vue.js源码解析-Vue初始化流程
目录 前言 1. 初始化流程概述图.代码流程图 1.1 初始化流程概述 1.2 初始化代码执行流程图 2. 初始化相关代码分析 2.1 initGlobalAPI(Vue) 初始化Vue的全局静态AP ...
- PTA题目集4-6总结
PTA题目集4-6总结 一:前言 在题集4-6中,所考查的主要知识点有正则表达式,类与类之间的调用,类的聚合,继承,封装,接口与多态,三种排序方法如选择排序,冒泡排序,插入排序,ArrayList,s ...
- asp.net core配合vue实现后端验证码逻辑
概述 网上的前端验证码逻辑总感觉不安全,验证码建议还是使用后端配合验证. 如果产品确定可以上网的话,就可以使用腾讯,百度等第三方验证,对接方便.但是产品可能内网部署,就必须自己写了. 本文章就是基于这 ...
- Android Gradle插件
目录 什么是Gradle 编写方法 buildSrc 基础概念 Extension 自定义Task Plugin Transformer Gradle用处 好文章 常见问题 Gradle插件练习地址: ...
- Java8-四个函数式接口(Consumer,Supplier,Predicate,Function)
Java8---函数式接口 Consumer---消费者(accept方法,Lambda与方法引用返回都是Consumer) Supplier---供给型(get方法,返回数据,与Optional可以 ...
- JS里的异步实例化
JS里的异步构造函数 众所周知,Js的构造函数是不能加上async/await来实现异步实例化的,一般当需要一个对象的属性是异步的结果时可以这样写: //! 一个需要指定时间后返回的异步函数 func ...