详解C语言四——数组(0基础思维理解二维数组)


一丶前言

先祝大家新年快乐!
初识C语言的文章中已经给大家介绍了关于数组的一些基本知识,本篇文章给大家较为详细的介绍一下数组。

数组是什么?(复习) 牢记:数组是一组相同类型元素的集合。 例如:记录全班同学的成绩,要统计用浮点数数据,一个一个的定义变量太麻烦,这时候就需要用数组了,把他们的成绩统一放到一个数组中。

二、学习目录

1.一维数组的有关知识。

由于前面的文章对数组已经有初步的认识,这里对一维数组我只是重点强调几点。
【1】数组在初始化时,[]中的数据必须是常量(C99标准之前,不考虑变长数组。)如:

int arr[10]={0];

【2】定义数组时要给数组初始化,数组的初始化是指,在创建数组的同时给数组的内容一些合理初始值。
【3】数组是使用下标来访问的,下标是从0开始。一定要牢记数组的下标是从0开始的。

我们重点介绍一下数组在内存中的储存,我们先记住结论:数组在内存中是连续存放的。
看下面这样一段代码:

#include <stdio.h>
int main()
{
 int arr[10] = {0};
 int i = 0;
 int sz = 10; 
 for(i=0; i<sz; ++i)
 {
 printf("&arr[%d] = %p\n", i, &arr[i]);
 }
 return 0; 
 }

代码是打印数组中元素的地址,我们来看看运行结果
在这里插入图片描述
我们可以看到随着数组下标的增长,元素的地址也在有规律的递增。
由此可以得出结论:数组在内存中并不是这里放一个,那里放一个,而是是连续存放的。

2.二维数组的有关知识。

【1】二维数组的创建和初始化
二维数组其实和一维数组是一个道理,二维数组可以这样创建和初始化,先看这个代码

int arr1[2][2] = {1,2,3,4};
int arr2[2][2] = {{1,2},{3,4}};
int arr3[][2] = {{1,2},{3,4}}

在这里插入图片描述

我们可以看到数组名后面有两个括号,我们这里可以这样理解(初始阶段方便理解):第一个括号是表示数组有多少,第二个括号是表示数组有多少
注意:二维数组在初始化时可以省略,一定不能省略。
【2】二维数组的使用。
类似于一维数组,二维数组也是使用数组下标的方式,例如,我们要打印二维数组中的每个元素。我们就可以这样写。

#include <stdio.h>
int main()
{
	int arr[2][2] = { 1,2,3,4 };
	int i = 0;
	for (i = 0; i < 2; ++i)
	{
		for (int j = 0; j < 2; j++)
		{
			printf("%d\n", arr[i][j]);
		}
	}
	return 0;
}

请看运行结果:
在这里插入图片描述
这与我们设想的一致。
【3】二维数组在内存中的储存。
二维数组在内存中像一维数组一样,也是连续储存的。
我们看这样一段代码:

#include <stdio.h>
int main()
{
	int arr[2][2] = { 1,2,3,4 };
	int i = 0;
	for (i = 0; i < 2; ++i)
	{
		for (int j = 0; j < 2; j++)
		{
			printf("%p\n",  &arr[i][j]);
		}
	}
	return 0;
}

这段代码是打印二维数组中的元素的地址的,我们来看运行结果。
在这里插入图片描述
我们可以看到随着数组下标的增长,二维数组中的元素的地址也在有规律的递增。
所以二维数组在内存中也是连续储存的。

3.数组名的含义

先记住结论:数组名是数组首元素地址。这里拿一维数组举例,我们来看这样一段代码。

#include <stdio.h>
int main()
{
	int arr[2] = { 1,2 };
	printf("%p\n", arr);
	printf("%p", &arr[0]);
	return 0;
}

这里打印数组名和数组第一个元素的地址,理论上讲打印的内容应该是一样的,我们来看运行结果:
在这里插入图片描述
这与我们设想的一致。
所以数组在函数传参时,实际传的是地址,所以形参也可以用指针来接受。

三丶总结

以上就是本篇文章要讲的内容,大体讲解了一维数组和二维数组的有关知识,方便大家学习,以便于更好的理解数组。
本篇文章内容结束,感谢大家观看。如果意见或建议,可以在评论区留言,您的点赞是我更新的动力。我们下篇文章再见。

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
使用malloc函数申请二维动态数组需要注意以下几点: 1. 二维数组在内存中的存储是连续的一片区域,因此需要先分配一维数组的空间,再为每个一维数组分配空间。 2. 为了方便起见,可以先通过一维数组的形式定义二维数组的行和列。 下面是一个示例程序,演示如何使用malloc函数申请二维字符串数组: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> int main() { int i, j, rows, cols; char **str_array; printf("Enter the number of rows: "); scanf("%d", &rows); printf("Enter the number of columns: "); scanf("%d", &cols); // 分配一维数组的空间 str_array = (char **) malloc(rows * sizeof(char*)); // 分配每个一维数组的空间 for(i = 0; i < rows; i++) { str_array[i] = (char *) malloc(cols * sizeof(char)); } // 输入字符串数组 printf("Enter the strings:\n"); for(i = 0; i < rows; i++) { scanf("%s", str_array[i]); } // 输出字符串数组 printf("The strings are:\n"); for(i = 0; i < rows; i++) { printf("%s\n", str_array[i]); } // 释放空间 for(i = 0; i < rows; i++) { free(str_array[i]); } free(str_array); return 0; } ``` 这个程序首先要求用户输入二维数组的行和列,然后使用malloc函数分配一维数组和每个一维数组的空间。接下来,程序允许用户输入字符串数组,并输出结果。最后,程序释放动态分配的内存。 需要注意的是,在释放空间时,需要先释放每个一维数组的空间,再释放一维数组的空间。这是因为每个一维数组的空间是通过malloc函数分配的,因此必须先释放它们的空间,否则可能会导致内存泄漏。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT牛爷爷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值