(七十八)嵌套和二维数组

简介:

例如int a[5]是一维数组,他是由a[0]、a[1]、a[2]、a[3]、a[4]这五个int类型的数组组成的。

 

如果放到excel里面,那么就是:

a[0]

a[1]

a[2]

a[3]

a[4]

 

这样一个样子,一维表示线。

一维数组的表示方法可以理解为:

变量名[横坐标x]

x初始为0,表示原点

 

假如表格从线到面,就升格为二维。

二维数组的的特点是既有横坐标,又有纵坐标。声明格式为:

int 变量名[纵坐标y][横坐标x]

表示每行有x个元素,每列有y行。

例如int a[3][4],放在表格里的表现形式为:

a[0][0]

a[0][1]

a[0][2]

a[0][3]

a[1][0]

a[1][1]

a[1][2]

a[1][3]

a[2][0]

a[2][1]

a[2][2]

a[2][3]

 

注意:之所以这么写,是因为在初始化的时候,先初始化第0行(实际上的第一行),再初始化第1行,再初始化第2行等。

 

二维数组可以这么理解;

先有数组a[x],然后这个数组里就有x个元素;

然后在数组a[x]的基础上,由y个a[x]数组组成的a[y][x]数组,于是就有a[y][x]——相当于是双重数组,第一个数组有4个成员,第二个数组有3个成员(且这3个成员每个都有4个成员);

 

假如分别初始化a[0]={}; 中括号里面的0,指的是y坐标,因此初始化的是第y+1行上的x坐标成员

 

例如将int a[3][4]进行初始化的代码如下:

//初始化二维数组
#include<iostream>
int main()
{
	using namespace std;
	double a[3][4] =
	{
		{0.0,0.1,0.2,0.3},	//第一行,注意,一行以大括号包围,大括号以逗号为结尾。
		{1.0,1.1,1.2,1.3},	//之所以以逗号为结尾,是因为数组成员之间以逗号为间隔,
		{2.0,2.1,2.2,2.3},	//若将一个大括号内的4个元素整体看做一个大数组的成员,那么这个大数组有三个成员
	};
	cout << "a[0][0] = " << a[0][0] << endl;	//输出大数组第一个成员中(第一行)的小数组第一个成员(第一列)
	cout << "a[0][1] = " << a[0][1] << endl;	//输出大数组第一个成员中(第一行)的小数组第二个成员(第二列)
	cout << "a[1][0] = " << a[1][0] << endl;	//第二行,第一列
	cout << "a[2][3] = " << a[2][3] << endl;	//第三行,第四列
	system("pause");
	return 0;
}

输出:

a[0][0] = 0
a[0][1] = 0.1
a[1][0] = 1
a[2][3] = 2.3
请按任意键继续. . .

总结:

①我觉得可以将二维数组理解为一个excel表格,只不过excel表格的初始横纵坐标都是1,而二维数组的初始横纵坐标是0。

 

②坐标输出是先横行,再纵列——先横后竖

 

③二维数组不仅支持int类型,也支持double类型,可以推断,也会支持char、string类型等。

代码:

//验证二维数组支持string类型
#include<iostream>
#include<string>
int main()
{
	using namespace std;
	string a[3][4] =
	{
		{"八","一","六","上"},
		{"三","五","七","中"},
		{"四","九","二","下"},
	};

	cout << "a[0][0] = " << a[0][0] << endl;	//输出大数组第一个成员中(第一行)的小数组第一个成员(第一列)
	cout << "a[0][1] = " << a[0][1] << endl;	//输出大数组第一个成员中(第一行)的小数组第二个成员(第二列)
	cout << "a[1][0] = " << a[1][0] << endl;	//第二行,第一列
	cout << "a[2][3] = " << a[2][3] << endl;	//第三行,第四列
	system("pause");
	return 0;
}

输出:

a[0][0] = 八
a[0][1] = 一
a[1][0] = 三
a[2][3] = 下
请按任意键继续. . .

④因为有二维数组,可以推断也有三维数组,或许也有四维数组。

格式类似,即 类型名 变量名[z][y][x]。然后每一个数组初始化结束后,用大括号括起来。

代码:


//验证有三维数组
#include<iostream>
#include<string>
int main()
{
	using namespace std;
	int a[2][3][4] =	//a[z][y][x]
	{
		{	//是z坐标第一面
			{000,001,002,003},	//y坐标第一行中的x坐标第1~4个
			{010,011,012,013},	//y坐标第二行
			{020,021,022,023},
		},	//以逗号结尾,因为可以把a[y][x]看成一个更大的数组中的一个成员
		{	//z坐标第二面
			{100,101,102,103},
			{110,111,112,113},
			{120,121,122,123},
		},
	};

	cout << "a[0][0][0] = " << a[0][0][0] << endl;	//输出z=0,y=0,x=0——注:=0为第一行,依次类推
	cout << "a[0][0][1] = " << a[0][0][1] << endl;	//输出z=0,y=0,x=1
	cout << "a[1][1][0] = " << a[1][1][0] << endl;	//输出z=1,y=1,x=0
	cout << "a[1][2][3] = " << a[1][2][3] << endl;	//输出z=1,y=2,x=3
	system("pause");
	return 0;
}

输出:


a[0][0][0] = 0
a[0][0][1] = 1
a[1][1][0] = 110
a[1][2][3] = 123
请按任意键继续. . .

⑤假如二维/三维数组的值是有规律的,例如跟三维坐标有关,于是可以利用for来给数组赋值:

代码:


#include<iostream>
#include<string>
int main()
{
	using namespace std;
	int a[2][3][4];	//a[z][y][x]
	int x = 0, y = 0, z = 0;
	
	for (z = 0;z < 2;z++)	
	{
		for (y = 0;y < 3;y++)	
		{
			for (x = 0;x < 4;x++)	
			{
				a[z][y][x] = z * 100 + y * 10 + x;
			}
		}

	}
	//逻辑是先判断z,然后判断y,然后判断x,这个时候,三个坐标都有确切数组了,于是根据算法,a[z][y][x]就有确切数值了
	cout << "a[0][0][0] = " << a[0][0][0] << endl;	//输出z=0,y=0,x=0——注:=0为第一行,依次类推
	cout << "a[0][0][1] = " << a[0][0][1] << endl;	//输出z=0,y=0,x=1
	cout << "a[1][1][0] = " << a[1][1][0] << endl;	//输出z=1,y=1,x=0
	cout << "a[1][2][3] = " << a[1][2][3] << endl;	//输出z=1,y=2,x=3
	system("pause");
	return 0;
}

输出和未使用for的是一样的


目录
相关文章
|
传感器 人工智能 监控
为什么需要数字孪生?数字孪生系统的目标是什么?
随着物联网越来越深入到各个领域,每一个车站、工厂、道路等都成为了一个设备密集、数据密集运行体,业务系统需要对接多种设备上报的海量多源异构实时数据,数据种类和频率都已经远远超过了传统网页表格类布局的承载和展示能力
546 0
软件开发常见流程之如何下载域名证书,由于域名备份需要域名证书,好的做法是提前将证书下载了,并且以xxxxx.com标记标题整理
软件开发常见流程之如何下载域名证书,由于域名备份需要域名证书,好的做法是提前将证书下载了,并且以xxxxx.com标记标题整理
|
移动开发 API 开发工具
秒懂云通信:如何使用阿里云号码认证服务(小白指南)
手把手教你如何使用阿里云号码认证服务,超详细控制台步骤解析,快速上手!
3060 0
秒懂云通信:如何使用阿里云号码认证服务(小白指南)
|
9月前
|
Java API Maven
使用Java和Spring Boot构建RESTful API
使用Java和Spring Boot构建RESTful API
84 0
|
存储 编解码 算法
高度优先左高树(Height-Based Left-Triangle,
高度优先左高树(Height-Based Left-Triangle,简称HBLT)是一种用于压缩图像和图形数据的算法。它通过将图像或图形分割成三角形,并对这些三角形进行编码和存储,从而实现压缩。这种方法可以在保持视觉质量的同时,有效地减小文件大小。
139 4
|
资源调度 JavaScript 前端开发
【TypeScript】Ts基本概念
【TypeScript】Ts基本概念
107 0
|
9月前
|
消息中间件 SQL 容灾
深度剖析 RocketMQ 5.0,消息进阶:如何支撑复杂业务消息场景?
本文主要学习 RocketMQ 的一致性特性,一致性对于交易、金融都是刚需。从大规模复杂业务出发,学习 RocketMQ 的 SQL 订阅、定时消息等特性。再从高可用的角度来看,这里更多的是大型公司对于高阶可用性的要求,如同城容灾、异地多活等。
108813 287
|
域名解析 弹性计算 NoSQL
飞天加速计划·高校学生在家实践——ECS服务器初体验
我当前是计算机专业研二学生,现就读于北京科技大学,主攻方向是计算机视觉(CV)中的图像分割,我们实验室也有GPU计算集群,不过在知乎偶然一次机会了解到阿里云的高校计划,从链接点进来后,经过一系列熟悉的操作,我慢慢了解到云服务器ECS这一概念。
|
Java 编译器 容器

热门文章

最新文章