vector详解(不定长数组)

news2024/9/28 11:23:11

目录

什么是vector

vector的介绍

模板的声明方式

vector的基本操作

push_back

insert 

erase 

遍历vector

小明爱数列-练习题

思路


什么是vector

vector的介绍

和我一样,我猜你们看到题目时心里都会产生一个疑问"什么是vector?(大佬除外)".vector其实是c++中的一种容器.总而言之,vector就是种特殊的"数组".什么样的数组呢?不定长数组!

不仅如此,他还把一些常规操作封装在了vector内部.

如果说栈是个弹夹,队列就是队列,那么vector就像个贪吃蛇(我的比喻没错吧),不定长度(真的和贪吃蛇的特征很相似) 

 当然,你们也可以把vector理解成队列的衍生类别(bushi).

其实vector和队列本质上几乎是没有相同的,我只是为了你们好理解(憋屈).

例如: v 是一个vector,和队列,栈一样,我们可以读取他的长度,改变他的大小,删除一个元素,在尾部添加一个元素,判断容器是否为空……一系列的作用

模板的声明方式

由于vector是一个模板,所以我们需要声明一个vector,声明方式如下:

vector<int> v;
vector<double> vd;
vector<char> vc;

vector<int> v;相当于声明一个int类型的数组:  int v[];
vector<double> vd;相当于声明一个double类型的数组: double vd[];
vector<char> vc; 相当于声明一个char类型的数组: char vc[];

相比较于普通的数组,vector有点那是只多不少:长度可变,内存动态分配,封装了许多的函数,可以删除插入选择……

接下来,我们来判断一下:

之所以vector的长度可变,是因为他一上来就申请了一个内存超级大的数组来保存数据,虽然你只在这里面使用了一小部分.

这句话对吗?大错特错!!!

vector的长度可变,是因为你加一个数进去,vector的长度就会增加,所以并不是说他一上来就申请了一个超级大的数组(内存:你礼貌吗?)  vector 内部包括了一个用来记录数据的数组,当我们不断向 vector 中增加元素时,这个数组也有空间用完的时候,这时 vector 内部会申请一个更大的新的数组,并将原数组中的数据复制到新数组中,之后替换原数组,这就是 vector ​​ 长度可变的秘密。

vector的基本操作

vector的函数以及其实现功能如下:

​
vector<int> v
v.clear()            //移除容器中所有数据。
v.empty()            //判断容器是否为空。
v.erase(pos)         //删除pos位置的数据
v.erase(beg,end)     //删除[beg,end)区间的数据
v.front()            //传回第一个数据。
v.insert(pos,elem)   //在pos位置插入一个elem拷贝
v.pop_back()         //删除最后一个数据。
v.push_back(elem)    //在尾部加入一个数据。
v.resize(num)        //重新设置该容器的大小
v.size()             //回容器中实际数据的个数。
v.begin()            //返回指向容器第一个元素的迭代器
v.end()              //返回指向容器最后一个元素的迭代器

​

 接下来,我们来讲几个比较重要的函数

push_back

push_back是vector最常用的函数之一,其作用就像是在vector的末尾添加一个新的元素(所以呢,push_back是有返回值的),感觉和队列里的push一模一样(没戳).

我们来举个栗子,定义一个vector<int> v;原本v数组里的长度为4(假设的),如果我们v.push_back(5).后,此时序列的长度就变成了5,最后一个元素是v[4],也就是5,vector的下标也是从0开始计算的.

vector<int> v
v.push_back(5);//在末尾添加一个5

insert 

insert()和push_back()不同,后者只能把新的元素添加在末尾,而insert却可以把新的元素放在指定的位置.那是不是insert可以完全代替push_back()呢?不不不!!别看insert比push_back厉害,两者的执行效率却截然不同.

对于insert() 操作,比如我们将元素放到位置3,则原来在位置3上的元素会向后移动一位,来到位置4,当然这样又会导致原来在位置4的元素也需要后移,因此insert() 在位置 3,会让3在内以及后面所有的元素都移动1位,效率比较低。

vector<int> v;
v.insert(v.begin()+3,128);
//将128插入到第三个下标(第四个元素)

erase 

erase()的作用是从vector当中删除元素,erase可以用来删除某一个元素,也可以来删除某一段元素.删除某一个元素时,给出来的参数是一个位置,这个位置不是简单的数字(像1,2,3,4之类的),他们是可以通过用begin()和end()计算出来的.

比如说我想删除下标为5的元素时,我们需要编写的函数的参数不是v.erase(5),而是v.erase(v.begin(5));如果你想删除一段数字的话就要带上开始位置和结束位置.

接着我们通过一个代码来理解一下以上程序的调用格式:

#include <bits/stdc++.h>
using namespace std;
vector<int> c;
int main(){
    //顺序访问
    for(int i=0;i<10;i++)
        c.push_back(i); //将数字 i 放在最后位置
    c.erase(c.begin()+5); //删除下标为5的元素
    c.insert(c.begin()+2,11); //把11插入到下标为2的位置
    //遍历并输出所有数字
    for(int i=0;i<c.size();i++)
        cout<<c[i]<<" ";
    return 0;
}

 结果运行如下:

0 1 11 2 3 4 6 7 8 9

从这个结果我们可以看到erase删除了5;

而insert又将11插入到了1和2之间;

不论是 insert还是erase,都需要begin和end来定位.

遍历vector

接下来我们来学习vector的遍历.

众所周知,数组是可以遍历的,那么vector可不可以遍历呢?当然可以啦,只不过和普通数组的遍历方式有点不一样罢了.

遍历vector的方式有两种

1.直接访问

2.迭代器访问

接着我们放一段代码,生动的教会了大家如何遍历vector

#include <bits/stdc++.h>
using namespace std;
vector<int>obj;
int main(){
    //顺序访问
    for(int i=0;i<10;i++)
        obj.push_back(i);
    cout<<"直接利用下标:";
    for(int i=0;i<obj.size();i++)//方法一 
        cout<<obj[i]<<" ";
    cout<<endl;
    cout<<"利用迭代器:";
    //声明一个迭代器,来访问vector容器,作用:遍历或者指向vector容器的元素 
    vector<int>::iterator it;
    for(it=obj.begin();it!=obj.end();it++)
        cout<<*it<<" ";
    return 0;
}

输出结果不用看了都是一样的:

直接利用数组:0 1 2 3 4 5 6 7 8 9

利用迭代器 :  0 1 2 3 4 5 6 7 8 9

对于二维的vector初始化我们还是需要注意一下的.直接使用:

vector<vector<int>> v

定义出来的是长度为0的二维数组.现在的二维数组我们没有办法访问他,当然push_back也不行,同时要注意定义的时候两个>符号一定要用空格隔开, 不然编译器会认为是输入输出流的符号。

二维数组定义的方式一般有两种:

//方法一:    
int N=5,M=6; 
vector<vector<int>>obj(N);              //定义二维动态数组大小5行 
for(int i=0;i<obj.size();i++)        //动态二维数组为5行6列,值全为0  
    obj[i].resize(M); 
//方法二:
vector<vector<int>>obj2(N,vector<int>(M));   //定义二维动态数组5行6列

 二维数组的本质是vector当中的vector.与之前学的二维数组不同,每一个vector大小都可以不同.

接下来我们来看一道题:

小明爱数列-练习题

小明非常喜欢数列,于是他提出了一个关于数列的问题。他拿到一个长度为 𝑛n 的数列,之后对这个数列进行了两种操作:

第一种:D x

表示删除数列第 x 位置的一个数字,后面的数字向前移动(若 x> 此时数列长度则操作无效);

第二种:Z x y

表示在数列的第 x 位置插入一个数字 y,后面的数字向后移动(若x>此时数列长度则在数列末尾插入 y);

经过k次这两种操作以后,小明想要知道现在的数列是什么,聪明的你可以帮助小明解决这个问题吗?

输入格式

输入包括k+2行数据; 第一行包括两个数n,k,分别表示数列中数的个数以及操作的次数,其中1=<k<=n<5000; 第二行n个数表示该数列的n个数,以空格隔开,其中任意数ai为int范围内的整数; 第三行到第k+2行,每行一个操作,格式见题面描述。

输出格式

输出包括两行; 第一行一个数m,表示全部操作之后数组的长度; 第二行m个数,表示当前的数组。

输入样例

4 3
4 5 2 1
Z 3 3
Z 0 1
D 2

输出样例

5
1 4 2 3 1

数据范围

对于10%的数据,1 <= n <= 4; 对于50%的数据,1 <= n <= 1024; 对于100%的数据,1 <= k<= n <=5000,且ai,x,y是int范围内的整数。

样例解释

初始数组为(4 5 2 1)

执行完Z 3 3得到(4 5 2 3 1)

执行完Z 0 1得到(1 4 5 2 3 1)

执行完D 2得到(1 4 2 3 1)

这道题是一道很明显用vector做的题,话不多说,我们直接上思路:

思路

调用vector 提供的标准函数操作数据即可.D对应 erase ,Z 对应insert.需要特判D和Z操作对应的位置,如果insert 的位置大于vect.size() ,加到最后就好,如果D的位置大于等于 vect.size() ,则不做操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/97013.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一起Talk Android吧(第四百四十四回:UI控件之DatePicker)

文章目录概念介绍使用方法内容总结各位看官们大家好&#xff0c;上一回中咱们说的例子是"UI控件之NumberPicker",这一回中说的例子是"UI控件之DatePicker"。闲话休提&#xff0c;言归正转&#xff0c;让我们一起Talk Android吧&#xff01; 概念介绍 看官…

CSS实现文字扫光特效

上大学的玩 ae 的时候&#xff0c;就曾遇到过这个特效。偶然在百度看到了类似特效&#xff0c;没想到竟然能用 css 实现&#xff0c;所以就研究了一下&#xff0c;文字扫光效果如下&#xff1a; 实现思路&#xff1a; 光效移动效果&#xff0c;可以通过 background-image 设置…

RCNN网络源码解读(Ⅲ) --- finetune训练过程

目录 0.回顾 1.finetune二分类代码解释&#xff08;finetune.py&#xff09; 1.1 load_data&#xff08;定义获取数据的方法&#xff09; 1.2 CustomFineTuneDataset类 1.3 custom_batch_sampler类&#xff08; custom_batch_sampler.py&#xff09; 1.4 训练train_mod…

JVM.......未完待续

一、了解 JVM JVM ( Java Virtual Machine )&#xff0c;又称之为 Java虚拟机。JVM 的运行与操作系统无关&#xff0c;能够实现跨平台&#xff0c;只要是安装了JVM的机器&#xff0c;都能运行Java程序&#xff0c;Java语言最重要的特点 "跨平台运行"&#xff0c;也…

关于应用形态数轴方法的一点展望

“既然目前物理化学关于物质世界的最高理论成果&#xff0c;即所谓由量子力学和统计力学组成的第一原理&#xff0c;只能求算物质无生命的性质&#xff0c;而药物设计关心的却是有生命的性质.那么是否第一原理对药物设计就无所作为呢&#xff1f;不是的.也就是说&#xff0c;尽…

设备资产管理系统有什么用?

在PC时代&#xff0c;电脑、打印设备的那个已经成为当代企业的必备资产&#xff0c;生产型企业还有生产设备等资产&#xff0c;企业规模越大资产就越多&#xff0c;就越难管理&#xff0c;因此设备资产管理系统成为诸多企业数字化管理的重要组成之一。设备管理系统的应用不仅能…

算法基础篇-10-动态规划

1. 简介 动态规划是一种算法思想&#xff1b; 动态规划递归式子问题 1.1 案例1&#xff1a; 斐波那契数列 斐波那契数列&#xff1a;FnFn-1Fn-2 代码演示&#xff1a; 使用递归和非递归的方法来求解斐波那契数列的第n项&#xff1b; 递归的方法&#xff1a; public static…

uniapp实战仿写网易云音乐(二)—视频页面(scroll-view组件实现横线滑动,mescroll-uni实现视频列表,向下滑动刷新当前页面)

文章目录前言顶部导航条的实现视频列表的展示部分CSS部分最后前言 接着上篇文章继续完成剩下的部分&#xff0c;本篇文章是完成第二个页面——视频页面的部分&#xff0c;视频还是没有做播放的效果&#xff0c;主要是做展示效果。下面附上两篇文章链接&#xff0c;没看过的同学…

【概率论】正态分布

前导知识&#xff1a; 概率密度函数&#xff08;密度函数&#xff09;&#xff1a;描述一个随机变量的在某个确定的取值点附近的可能性的函数。 随机变量的取值落在某个区域内的概率为概率密度函数在这个区域上的积分。 性质&#xff1a; f(x)>0 数学期望 又称均值&am…

vue组件

9.Vue组件 组件&#xff08;Component&#xff09;是 Vue.js 最强大的功能之一。 组件可以扩展 HTML 元素&#xff0c;封装可重用的代码。 组件系统让我们可以用独立可复用的小组件来构建大型应用&#xff0c;几乎任意类型的应用的界面都可以抽象为一个组件树&#xff1a; 9…

SpringBoot 自定义starter yaml提示失效问题

自定义starter yaml提示失效问题自定义starter yaml提示失效问题问题场景解决办法自定义starter yaml提示失效问题 问题场景 在自定义starter后&#xff0c;必不可少会有properties配置参数需要指定&#xff0c;而在有时又不知道为什么出现这个问题。官方 Configuration Meta…

玩以太坊链上项目的必备技能(OOP-抽象合约-Solidity之旅十)

抽象合约&#xff08;abstract contract&#xff09; 前文在讲合约继承的基类构造函数的参数时&#xff0c;有提到抽象合约&#xff0c;也就是说&#xff0c;如果派生合约未能给其继承的基合约指定构造函数参数时&#xff0c;那么&#xff0c;该派生合约必须声明为抽象合约&am…

ubuntu中安装tippecanoe并切片

概述 本文是一片”水文”&#xff0c;记录一下如何在ubuntu中用tippecanoe制作矢量切片。 实现操作 本示例中ubuntu是在VMware虚拟机中&#xff0c;安装的是18.04.6的版本&#xff0c;你可通过我兰的镜像下载&#xff0c;速度杠杠的。 1.安装git sudo apt install git2.cl…

探索SpringMVC-HandlerMapping之RequestMappingHandlerMapping

前言 上回我们知道HandlerMapping是用来寻找Handler的&#xff0c;并不与Handler的类型或者实现绑定&#xff0c;而是根据需要定义的。那么为什么要单独给RequestMapping实现一个HandlerMapping&#xff1f;这次咱们就来专门看看这个RequestMappingHandlerMapping。 RequestM…

Educational Codeforces Round 139 (Rated for Div. 2)(A~E)

A. Extremely Round 定义一个数中仅存在一位非0&#xff0c;它是extremely round&#xff0c;计算1~n中有几个满足条件的数。 思路&#xff1a;直接计算即可。 AC Code&#xff1a; #include <bits/stdc.h>typedef long long ll; const int N 1e5 5; int t, n;int c…

高手必备10大难题:Mysql如何实现RR级隔离时,不会幻读?

文章很长&#xff0c;而且持续更新&#xff0c;建议收藏起来&#xff0c;慢慢读&#xff01;疯狂创客圈总目录 博客园版 为您奉上珍贵的学习资源 &#xff1a; 免费赠送 :《尼恩Java面试宝典》 持续更新 史上最全 面试必备 2000页 面试必备 大厂必备 涨薪必备 免费赠送 经典…

[2022-12-17]神经网络与深度学习第5章 - 循环神经网络(part 1)

contents循环神经网络 part 1 - RNN记忆能力实验写在开头循环神经网络的记忆能力实验数据集构建数据集构建函数数据集加载构建 Dataset类模型构建嵌入层SRN层自己实现torch框架实现比较线性层模型汇总模型训练训练指定长度的数字预测模型模型评价写在最后循环神经网络 part 1 -…

[机器人学习]-树莓派6R机械臂运动学分析

根据D-H表规定得到如下变换矩阵为&#xff1a; 由此可得机器人相邻两关节位姿分别为&#xff1a; 根据DH参数求解变换矩阵的函数trans&#xff1a; %输入JD&#xff0c;即6个关节变量的值&#xff0c;求解正运动方程 function [ T ] trans( theta, d, a, alpha ) T [ cos(th…

Java中Stream的 flatMap 与 map 实际使用场景与区别对比

基本概念 Stream 流式操作&#xff0c;一般用于操作集合即 List 一类的数据结构&#xff0c;JDK 1.8 后的新特性 Stream 中的 map 一般用于对List 中的每一个元素执行指定方法使得最终结果为最终的集合为每一个记录的某一属性的集合&#xff08;get 方法&#xff09;或者通过…

PPT怎么转PDF?将Powerpoint(PPT)转换为PDF方法分享

当您在PowerPoint中创建精美的演示文稿时&#xff0c;您不仅想给观众留下深刻的印象&#xff0c;还希望它能够方便地打包&#xff0c;并且文件格式起着重要作用。虽然PPTX是一种广泛传播的格式&#xff0c;但PDF始终是一个安全的选择。以下是有关如何使用在线工具将PowerPoint演…