数组的概念
数组是一组相同的类型元素的集合,从这句话我们可以知道
- 数组里存放一个或多个数据,但不能是零个
- 数组中存放多个数据,必须是同种类型
一维数组的创建和初始化
数组创建
type arr_name[常量值];
存放到数组里的值称为数组的元素,创建时可以决定元素的个数大小和类型
- type指的是存放数据的类型,包含int、char、float、double、void、
- arr_name指的是数组的名字更具实际意义来写,有意义就行
- []指的是元素的个数
数组的初始化
//数组的初始化
int arr1[10] = {1,2,3,4,5,6,7,8,9,10};
//数组的不完全初始化
int arr2[6] = {1,2,3,4,5}
int arr3[5] = {0}
//错误的初始化
int arr4[3] = {1,2,3,4}
数组的类型
arr1的数组类型是:int (数组名)[10]
arr2的数组类型是:int (数组名)[6]
arr3的数组类型是:int (数组名)[5]
一维数组的使用
⼀维数组可以存放数据,存放数据的⽬的是对数据的操作,那我们如何 使⽤⼀维数组呢?
数组下标
下标从0开始,如果有n个元素,那么最后一个元素的下标是n-1
C语言中提供了一个操作符[],这个操作符叫做下标引用操作符
#include<stdio.h>
int mian(){
int arr[10] = {1,2,3,4,5,6,7,8,9,10};
printf("%d\n",arr[3]); //4
printf("%d\n",arr[6]); //7
return 0;
}
可以通过下标去访问元素,代码如上
数组的输入和输出
数组输出
如果想要访问到数组的各个元素,可以使用for循环
#include<stdio.h>
int main(){
int arr[10] = {1,2,3,4,5,6,7,8,9,10};
int r = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for(i = 0;i < r;i++){
printf("%d",arr[i]);
}
return 0;
}
运行结果如下
数组输入
方法和上一样,代码如下
#include<stdio.h>
int main() {
int arr[10] = { 0 };
int r = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for (i = 0; i < r; i++) {
scanf("%d", &arr[i]);
}
for (i = 0; i < r; i++) {
printf(" %d", arr[i]);
}
return 0;
}
输入输出结果如下
一维数组在内存中的存储
有上面的知识,下面应该也是没什么障碍了
#include<stdio.h>
int main() {
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
int r = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for (i = 0; i < r; i++) {
printf("%p\n", &arr[i]);
}
return 0;
}
运行结果如下
二维数组元素的创建和初始化
二维数组的概念
前⾯学习的数组被称为⼀维数组,数组的元素都是内置类型的,如果我们把⼀维数组做为数组的元 素,这时候就是⼆维数组,⼆维数组作为数组元素的数组被称为三维数组,⼆维数组以上的数组统称 为多维数组。
二维数组的创建
语法如下
type arr_name[常量值1][常量值2];
//常量值1代表 “行”
//常量值2代表 “列”
二维数组的初始化
和一维数组一样,如下所示
//二维数组的初始化
int arr1[2][4] = {1,2,3,4,5,6,7,8};
//二维数组的不完全初始化
int arr2[3][5] = {1,2,3,4,5,6,7,8,9}
//二维数组的不完全初始化
int arr3[2][3] = {1,2,3,4,5,6,7}
注意:二维数组中行可以省略,列不可以省略
二维数组的使用
二维数组的下标
和一维数组一样
C语言中,二位数组的行从0开始的,列也是从0开始的
和一维数组一样,也是通过下标去访问各个元素
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][3]);
return 0;
}
运行结果如下
二维数组的输入和输出
#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;
int j = 0;
//输入
for (i = 0; i < 3; i++) {
for (j = 0; j < 5;j++) {
scanf("%d", &arr[i][j]);
}
}
//输出
for (i = 0; i < 3; i++) {
for (j = 0; j < 5;j++) {
printf("%d", arr[i][j]);
}
printf("\n");
}
return 0;
}
运行结果如下
由此可遍历每一行每一列
二维数组在内存中的存储
像一维数组一样我们也可以打印出二维数组里各个元素的地址
#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++) {
printf("&arr[%d][%d] = %p\n",i,j,&arr[i][j]);
}
}
return 0;
}
运行结果如下
从输出的结果来看,每⼀⾏内部的每个元素都是相邻的,地址之间相差4个字节,跨⾏位置处的两个元 素(如:arr[0][4]和arr[1][0])之间也是差4个字节,所以⼆维数组中的每个元素都是连续存放的。
了解了二维数组在内存中的布局,有利于我们后面学习指针噢
今天就分享到这里了,
如有讲出的的地方,欢迎大家评论,
我们一起加油!!!