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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mysql存储过程菜鸟教程_mysql存储过程是什么

    mysql存储过程菜鸟教程_mysql存储过程是什么本文介绍关于在MySQL存储过程游标使用实例,包括简单游标使用与游标循环跳出等方法例1、一个简单存储过程游标实例DELIMITER$$DROPPROCEDUREIFEXISTSgetUserInfo$$CREATEPROCEDUREgetUserInfo(indate_daydatetime)—-实例–存储过程名为:getUserInfo–参数为:date_day…

    2022年10月1日
    0
  • Java 多线程编程

    Java 多线程编程

    2021年5月6日
    103
  • 显卡机器linux 6卡挖矿,显卡挖矿是什么意思?购买显卡矿机应该注意什么?

    显卡机器linux 6卡挖矿,显卡挖矿是什么意思?购买显卡矿机应该注意什么?提到挖矿,很多人都比较感兴趣,众所周知,挖矿是除了直接交易数字货币之外,获取数字货币的唯一途径,而挖矿会根据不同的数字货币定义成不同的挖矿形式,比如说最近比较火的流动性挖矿,就是投资者抵押或锁定加密货币以换取报酬的做法,还有就是本文要说的显卡挖矿,下面小编就给大家通俗的讲解一下显卡挖矿是什么意思。显卡挖矿是什么意思?显卡挖矿其实就是用显卡去挖比特币,让显卡高负荷工作挖,淘汰了的就成了矿卡,矿卡一般…

    2022年6月10日
    43
  • TCP与udp区别_个人总结和工作总结的区别

    TCP与udp区别_个人总结和工作总结的区别TCP与UDP区别总结:1、TCP面向连接(如打电话要先拨号建立连接);UDP是无连接的,即发送数据之前不需要建立连接2、TCP提供可靠的服务。也就是说,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达;UDP尽最大努力交付,即不保证可靠交付3、TCP面向字节流,实际上是TCP把数据看成一连串无结构的字节流;UDP是面向报文的UDP没有拥塞控制,因此网络出现拥塞不会使源主机的发送速率降低(对实时应用很有用,如IP电话,实时视频会议等)4、每一条TCP连接只能是点到点的;UDP

    2022年9月5日
    2
  • 【面试】阿里巴巴Java经典面试题整理及答案详解

    【面试】阿里巴巴Java经典面试题整理及答案详解Java开发工程师-面试题目集锦Java的数据结构有哪些?线性表,链表,栈,队列,图,树什么是OOP?面向对象编程面向对象编程的原则有哪些?单一职责原则:一个类中应该是一组相关性很高的函数、数据的封装! 开闭原则;对扩展开放,对修改关闭,即在设计一个模块的时候,应当使这个模块可以在不被修改的前提下被扩展。 里氏替换原则:所有引用基类的地方必须能透明地使用其子类的对象。只…

    2022年7月8日
    18
  • linux中安装pycharm_ubuntu激活成功教程pycharm

    linux中安装pycharm_ubuntu激活成功教程pycharm前言由于学习需要,准备开始在linux环境下使用python。一开始是使用了vim作为编译器的,我承认vim确实很简洁,然而对于我这种新手来说确实是很低效,一开始用vim写代码真的是让我重新体会了一遍VC手撸C语言的感觉,而且面对了还是tf这种函数巨多的库。因此还是转去用了pycharm,可能我注定和大神无缘吧,逼格都提升不到。这篇文章主要介绍linux下的安装、环境配置和学生优惠。安装…

    2022年8月28日
    0

发表回复

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

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