C++ vector的初始化「建议收藏」

C++ vector的初始化「建议收藏」C++vector的初始化一维数组的初始化1.vector<int>v;2.vector<int>v={1,2,3,4,5};3.vector<int>v(n);vector<int>v(n,m);4.vector<int>v(v0);5.vector<int>…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一维数组的初始化

1. vector < int > v;

这时候v的size为0,如果直接进行访问 v[i] 会报错。
这里可以使用 v.resize(n),或者v.resize(n, m) 来初始化
前者是使用n个0来初始化,后者是使用n个m来初始化。

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

可以使用初始化数组的方式来初始化vector,如例子所示,此时v.size() == 5
如果这时候使用v.resize(3),将会丢弃最后的4和5。
注意,我是用的是vs2017,可能之前的编译器不支持这个初始化。

3. vector < int > v(n); vector < int > v(n,m);

类似于resize的用法

4. vector < int > v(v0);

使用另外一个数组来初始化v,注意,这里的v0也必须是vector
也可以写作vector < int > v = v0;

5. vector < int > v(*p, *q);

使用另外一个数组的指针来初始化v,这里即可以使用vector的指针,也可以使用普通数组的指针。 见例:

	int a[3] = { 1,2,3 };
	vector<int> v = {1,2,3,4};
	
	vector<int> v2(a, a+2);
	for (int i = 0; i < v2.size(); i++)
		cout << v2[i] << " ";          //输出为1 2
	cout << endl;
	
	vector<int> v3(v.begin()+1, v.end() - 1);
	for (int i = 0; i < v3.size(); i++)
		cout << v3[i] << " ";   		//输出为2 3

二维数组的初始化

1.vector < vector < int > > v;

和一维数组一样,这里的v的size是0。
可以先v.resize(n)来初始化一个长度为n的二维数组,然后使用一个for循环

		for (int i = 0; i < v.size(); i++)
			v[i].resize(n);

这样v的大小就是n*n。
也可以v.resize(n, v0),使用n个一维数组来初始化一个二维数组。
这里v0可以直接使用vector(n,m)来表示,比如

vector<vector<int>> v(3, vector<int>(4,1));

3*4大小的二维数组,值全为1.

2.vector < vector < int > > v(n, v0);

这个和resize的用法一样。

3. 拷贝构造和赋值就不赘述了

4.使用指针初始化

和一维数组类似,可以使用vector指针

		vector<int> v0 = { 1,2,3,4 };
		vector<vector<int>> v1(4, v0);
		vector<vector<int>> v(v1.begin()+1, v1.end()-1); //此时的v是 {
  
  {1,2,3,4},{1,2,3,4}}

如果使用一个二维数组指针来初始化vector时,出现了一个我无法理解的情况。

	int a[4][5] = { {1,2,3,4,0},{5,6,7,8,0},{9,10,11,12,0},{13,14,15,16,0} };

	vector<vector<int>> v(a[0], a[1]);

	for (int i = 0; i < v.size(); i++) {
		for (int j = 0; j < v[i].size(); j++)
			cout << v[i][j] << " ";
		cout << endl;
	}  
	/*
		此时的输出为
		0
		0 0
		0 0 0
		0 0 0 0
	*/

这个问题暂留。

三维数组的初始化

vector<vector<vector<int >>> v(i, vector<vector <int>>(j, vector < int>(k)));

这样就初始化了一个ijk的三维数组,当然也可以像前面二维数组的resize一样,指定初始化的值,这里就不多赘述了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192310.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm企业版激活码破解方法

    pycharm企业版激活码破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    144
  • siamfc++代码_asic芯片设计

    siamfc++代码_asic芯片设计SiamFC论文解读及代码实现摘要:传统上,任意目标跟踪的问题是通过专门在线学习目标外观的模型来解决的,使用视频本身作为唯一的训练数据。尽管这些方法取得了成功,但他们的纯在线方法固有地限制了他们可以学习的模型的丰富性。最近,有人试图利用深层卷积网络的表达能力。然而,当要跟踪的目标事先未知时,需要在线执行随机梯度下降以适应网络的权重,这严重影响了系统的速度。在本文中,我们在ILSVRC15数据集上为视频中的目标检测配备了一个基本的跟踪算法和一个新的端到端训练的孪生神经网络。我们的跟踪器以超过实时的帧速率运

    2022年10月1日
    2
  • Linux 常用命令 tar 打包文件夹

    Linux 常用命令 tar 打包文件夹linuxzip压缩。压缩当前文件夹下所有文件,压缩为a.zip。zip-rfileName.zip文件夹名linuxtar打包(可以不压缩哦~)tar命令可以用来压缩打包单文件、多个文件、单个目录、多个目录。单个文件压缩打包tarczvfmy.tarfile1多个文件压缩打包tarczvfmy.tarfile1file2,…单个目…

    2022年5月6日
    75
  • 机器学习-常用回归算法归纳(全网之最)

    机器学习-常用回归算法归纳(全网之最)文章目录前言一元线性回归多元线性回归局部加权线性回归多项式回归Lasso回归&Ridge回归Lasso回归Ridge回归岭回归和lasso回归的区别L1正则&L2正则弹性网络回归贝叶斯岭回归Huber回归KNNSVMSVM最大间隔支持向量&支持向量平面寻找最大间隔SVRCART树随机森林GBDTboosting思想AdaBoost思想提升树&梯度提升GBDT面试题整理XGBOOST面试题整理LightGBMXGBoost的缺点LightGBM的优化基于Hist

    2022年8月21日
    9
  • linux运行jar包的命令_linux部署jar包的几种方式

    linux运行jar包的命令_linux部署jar包的几种方式要运行java的项目需要先将项目打包成war包或者jar包,打包成war包需要将war包部署到tomcat服务器上才能运行。而打包成jar包可以直接使用java命令执行。在linux系统中运行jar包主要有以下几种方式。一、java-jarXXX.jar这是最基本的jar包执行方式,但是当我们用ctrl+c中断或者关闭窗口时,程序也会中断执行。二、java-jarXXX.jar&&代表在后台运行,使用ctrl+c不会中断程序的运行,但是关闭窗口会中断程序的运行。

    2022年10月4日
    1
  • Dubbo 负载均衡策略和集群容错策略都有哪些?动态代理策略呢?

    Dubbo 负载均衡策略和集群容错策略都有哪些?动态代理策略呢?面试题dubbo负载均衡策略和集群容错策略都有哪些?动态代理策略呢?面试官心理分析继续深问吧,这些都是用dubbo必须知道的一些东西,你得知道基本原理,知道序列化是什么协议,还得知道具体用dubbo的时候,如何负载均衡,如何高可用,如何动态代理。说白了,就是看你对dubbo熟悉不熟悉:dubbo工作原理:服务注册、注册中心、消费者、代理通信、负载均衡; 网络通…

    2022年7月11日
    23

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号