数组的概念
什么是数组?数组是一组相同类型元素的集合。我们可以从概念中知道:
一维数组
1.一维数组的创建和初始化
1.1 数组的创建
一维数组创建的基本语法如下:
type_t arr_name [const_n];
//type_t 是指数组的元素类型
//arr_name 是数组的名字
//const_n 是一个常量表达式,用来指定数组的大小
注:[ ]中的常量值是用来指定数组的大小的,这个数组的大小是根据实际情况的需求指定就行。
比如:我们现在想存储某个班级30个人的英语成绩,那我们可以创建一个数组:
int English[30];
当然我们也可以创建其他类型和大小的数组:
char ch[10];
double score[15];
1.2 数组的初始化
//完全初始化
2 int arr[5] = {1,2,3,4,5};
3
4 //不完全初始化
5 int arr2[6] = {1};//第⼀个元素初始化为1,剩余的元素默认初始化为0
6
7 //错误的初始化 - 初始化项太多
8 int arr3[3] = {1, 2, 3, 4};
1.3 数组的类型
int arr1[10];
int arr2[12];
char ch[5];
arr1数组的类型是 int [10]arr2数组的类型是 int[12]ch 数组的类型是 char [5]
2.一维数组的使用
学习了一维数组的基本语法,那我们该如何使用呢?
2.1 数组下标
int arr[10]={1,2,3,4,5,6,7,8,9};
2.2 数组元素的打印
#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5,6,7,8,9,10};
int i = 0;
for(i=0; i<10; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
输出的结果为:
3.一维数组在内存中的存储
#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5,6,7,8,9,10};
int i = 0;
for(i=0; i<10; i++)
{
printf("&arr[%d] = %p\n ", i, &arr[i]);
}
return 0;
}
输出结果是:
从输出的结果我们分析,数组随着下标的增长,地址是从小到大变化的,并且我们发现每两个相邻的元素之间相差4(因为一个整型是4个字节)。所以我们得出结论:数组在内存中是连续存放的。
4.sizeof计算数组元素个数
#include <stido.h>
int main()
{
int arr[10] = {0};
printf("%d\n", sizeof(arr));
return 0;
}
#include <stido.h>
int main()
{
int arr[10] = {0};
printf("%d\n", sizeof(arr[0]));//计算⼀个元素的⼤⼩,单位是字节
return 0;
}
#include <stido.h>
int main()
{
int arr[10] = {0};
int sz = sizeof(arr)/sizeof(arr[0]);
printf("%d\n", sz);
return 0;
}
总结:
1.sizeof()操作符用于取长度,以字节为单位。sizeof(数组名)即求的时整个数组的大小。2.sizeof(首元素)即求数组单个元素大小。用0下标,是因为数组至少存在一个有效元素,所以0下标永远存在。
3.数组是使用下标来访问的,下标是从0开始。
4.数组的大小可以通过计算得到。建议采用sizeof(arr)/sizeof(arr[0])这种方式。
二维数组
1.二维数组的概念
2.二维数组的创建
type arr_name[常量值1][常量值2];
例如:
int arr[3][5];
double data[2][8];
解释:• 3表示数组有3行• 5表示每一行有5个元素• int 表示数组的每个元素是整型类型• arr 是数组名,可以根据自己的需要指定名字
3.二维数组的初始化
二维数组和一维数组一样,也是使用大括号初始化的。
3.1 不完全初始化
int arr1[3][5] = {1,2};
int arr2[3][5] = {0};
3.2 完全初始化
int arr3[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
3.3 按照行初始化
int arr4[3][5] = {{1,2},{3,4},{5,6}};
3.4 初始化时省略行,但是不能省略列
int arr5[][5] = {1,2,3};
int arr6[][5] = {1,2,3,4,5,6,7};
int arr7[][5] = {{1,2}, {3,4}, {5,6}};
4.二维数组的使用
4.1 二维数组的下标
int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
图中最右侧绿色的数字表示行号,第一行蓝色的数字表示列号,都是从0开始的,比如,我们说:第2行,第4列,快速就能定位出7。
#include <stdio.h>
int main()
{
int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
printf("%d\n", arr[2][4]);
return 0;
}
结果如下:
4.2二维数组的输入和输出
#include <stdio.h>
int main()
{
int arr[3][5] = {1,2,3,4,5, 2,3,4,5,6, 3,4,5,6,7};
int i = 0;//遍历⾏
//输⼊
for(i=0; i<3; i++) //产⽣⾏号
{
int j = 0;
for(j=0; j<5; j++) //产⽣列号
{
scanf("%d", &arr[i][j]); //输⼊数据
}
}
//输出
for(i=0; i<3; i++) //产⽣⾏号
{
int j = 0;
for(j=0; j<5; j++) //产⽣列号
{
printf("%d ", arr[i][j]); //输出数据
}
printf("\n");
}
return 0;
}
输入和输出的结果为:
4.3二维数组在内存中的存储
像一维数组一样,我们如果想研究二维数组在内存中的存储方式,我们也是可以打印出数组所有元素的地址的。
#include <stdio.h>
int main()
{
int arr[3][5] = { 0 };
int i = 0;
int j = 0;
for (i = 0; i < 3; i++)
{
for (j = 0; j < 5; j++)
{
printf("&arr[%d][%d] = %p\n", i, j, &arr[i][j]);
}
}
return 0;
}
输出结果:
通过结果我们可以分析到,每一行内部的每个元素都是相邻的,地址之间相差4个字节,跨行位置处的两个元素(如:arr[0][4]和arr[1][0])之间也是差4个字节,所以二维数组中的每个元素都是连续存放的。
注:
- 二维数组在内存的空间布局上,也是线性连续且递增的!!!
- 二维数组本质上也是一维数组,只不过内部元素放的是一维数组。
以上就是这次关于C语言数组的内容,希望同学们学完后对数组能有更好的理解。