C语言入门【二维数组】

前言

我们前面讲了一维数组,那这次就来讲多维数组;其中我会用二维数组来代表多维数组,因为二维数组是多维数组中最常见的。

1 二维数组

一维数组将每个数据看作数组的每个元素,那么同理,将每个一维数组看作是数组的每个元素,这就是二维数组,将二维数组看作是数组的元素,就称为三维数组。二维数组以上的都被称为多维数组

1.1 二维数组的创建

type arr_name[常量值1][常量值2];

 例如: `int arr[3][5];
        double data[3][4];`

解释:代码 int arr[3[5]; 出现的情况

int 为数组内每个元素都是整型类型
arr 是数组名,可以根据实际需求取有意义的名字
3 表示这个数组有3行
5 表示这个数组一行内有5个元素

double data[3][4]意思基本一致。

1.2 二维数组的初始化

二维数组的初始化和一维数组一样,都是用大括号 {}
二维数组初始化一共有4种

1.完全初始化

int main()
{
	//完全初始化
	int arr1[3][4] = { 1,2,3,4, 2,3,4,5, 3,4,5,6 };
	return 0;

在这里插入图片描述

2.不完全初始化

int main()
{
    //不完全初始化
	int arr2[3][4] = { 1,2 };
	int arr3[3][4] = { 0 };
	return 0;
}

在这里插入图片描述

在这里插入图片描述

3.按照行初始化

int main()
{

	//根据行来初始化
	int arr4[3][4] = { {1,2},{2,3},{3,4} };
	return 0;
}

在这里插入图片描述

1.3 二维数组初始化可以省略行,但不能省略列

逻辑也很简单,在有列的情况下,每行的列满了会自动到下一行,如果在下一行内数据全部存入完了但没有填满一行,那么会自动补0(也就是不完全初始化);但如果没有列,那么在存入数据时,数组不知道什么时候才填满这一行,如果省略了列,VS会报错!!!

int main()
{
	int arr5[][5] = { 1,2 };
	int arr6[][5] = { 1,2,3,4,5,6,7 };
	int arr7[][5] = { {1,2},{3,4},{5,6} };
	return 0;
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.4 二维数组的使用

1.4.1 二维数组的下标

当我们掌握了⼆维数组的创建和初始化,那我们怎么使用二维数组呢?
其实⼆维数组访问也是使用下标的形式的,⼆维数组是有行和列的,只要锁定了行和列就能唯⼀锁定数组中的⼀个元素。
C语言规定了,二维数组的行和列都是从零开始的,如下所示:

int main()
{
	int arr1[3][4] = { 1,2,3,4, 2,3,4,5, 3,4,5,6 };
	return 0;

在这里插入图片描述
图中最右侧红色的数字表示行号,第一行蓝色的数字表示列号,都是从零开始,比如;如果我们要找到6这个数字,就可以说第2行,第3列,这样就能快速的定位到6了。

#include <stdio.h>
int main()
{
	int arr1[3][4] = { 1,2,3,4, 2,3,4,5, 3,4,5,6 };
	printf("%d", arr1[2][3]);
	return 0;
}

运行结果:
在这里插入图片描述

1.4.2 二维数组的输入与输出

我们已经知道如何访问二维数组的单个元素了,那如何才能访问整个二维数组呢?
其实我们只需要按照一定的规律,产生所有的行号和列号所对应的数字就可以了;我们用上面的代码的 arr数组 为例子,行号的取值范围是 0 ~ 2,列号的取值范围是 0 ~ 3,所以我们可以借助循环来生成所有的下标。

#include<stdio.h>
int main()
{
	int arr[3][4] = { 1,2,3,4, 2,3,4,5, 3,4,5,6 };
	int i = 0;
	//输入
	for (i = 0; i < 3; i++)//生产行号
	{
		int j = 0;
		for (j = 0; j < 4; j++)//生产列号
		{
			scanf("%d", &arr[i][j]);//输入数据
		}
	}

	//输出
	for (i = 0; i < 3; i++)//生产行号
	{
		int j = 0;
		for (j = 0; j < 4; j++)//生产列号
		{
			printf("arr[%d][%d] = %d\n", i, j, arr[i][j]);//打印数据
		}
	}

  return 0;
}

运行结果如下:

在这里插入图片描述

1.4.3 二维数组在内存中的存放

和一维数组一样,我们如果想要知道二维数组的存储方式,也是可以打印出数组所有元素的地址。
代码如下:

#include <stdio.h>
//打印数组地址
int main()
{
	int arr1[3][4] = { 1,2,3,4, 2,3,4,5, 3,4,5,6 };
	int i = 0;
	for (i = 0; i < 3; i++)
	{
		int j = 0;
		for (j = 0; j < 4; j++)
		{
			printf("arr[%d][%d] = %p\n", i, j, &arr1[i][j]);
		}
	}

	return 0;
}

结果如下:
在这里插入图片描述
从输出的结果来看,每⼀⾏内部的每个元素都是相邻的,地址之间相差4个字节,跨⾏位置处的两个元素(如:arr[0][3]和arr[1][0])之间也是差4个字节,所以我们可以得知,⼆维数组中的每个元素都是连续存放的。
如下图所示:
在这里插入图片描述

结语

感谢您能阅读完此片文章,如果有任何建议或纠正欢迎在评论区留言。如果您认为这篇文章对您有所收获,点一个小小的赞就是我创作的巨大动力,谢谢!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值