每天进步一点点,希望的火苗不熄灭。
目录
一、一维数组的创建和初始化
1. 一维数组的创建
数组是一组具有相同类型元素的集合。
数组的创建方式:
type_t arr_name [const_n];
//type_t : 数组的元素类型;
//arr_name :数组名;
//const_n : 一个常量表达式,用来指定数组的大小;
数组创建的实例:
//代码1:
int arr1[10]; //在内存中开辟能够存储10个int型的内存空间
char arr3[10]; //在内存中开辟能够存储10个char型的内存空间
float arr4[1]; //在内存中开辟能够存储1个float型的内存空间
double arr5[10]; //在内存中开辟能够存储10个double型的内存空间
//代码2
int count = 10;
int arr2[count];//数组时候可以正常创建?
如上所示代码2创建数组的方法是不对的,因为count是一个变量。
数组创建时 [ ] 中要给一个常量才可以,不能使用变量。
2. 一维数组的初始化
数组的初始化是指:在创建数组的同时给数组的内容一些合理初始值(初始化)。看代码:
//指定数组大小并进行初始化
int arr1[10] = {1,2,3}; //不完全初始化,将数组前三个元素进行初始化
int arr3[5] = {1,2,3,4,5};
char arr4[3] = {'a',98, 'c'};
//没有指定数组大小并进行初始化
int arr2[] = {1,2,3,4};
char arr5[] = {'a','b','c'};
char arr6[] = "abcdef";
指定数组大小时:数组大小为我们提前写入的大小;
没有指定数组大小时:数组的大小是根据初始化的内容决定的。
区分如下所示的代码:
char arr1[] = "abc";
char arr2[3] = {'a','b','c'};
eg:arr1在实际存储时是要在最后存储一个'\0'的。
3. 一维数组的使用
数组的使用:
在这里我们要用到一个操作符:
[ ]
下标引用操作符。它其实就数组访问的操作符。 我们来看代码:
#include <stdio.h>
int main()
{
int arr[10] = {0};//数组的不完全初始化
//计算数组的元素个数
int sz = sizeof(arr)/sizeof(arr[0]);
//对数组内容赋值,数组是使用下标来访问的,下标从0开始。所以:
int i = 0;//做下标
for(i=0; i<10; i++)
{
arr[i] = i;
}
//输出数组的内容
for(i=0; i<10; ++i)
{
printf("%d ", arr[i]);
}
return 0;
}
以上我们利用for循环完成对数组的初始化a[0]~a[9]分别存放0~9,最后再利用一个for循环完成对数组元素的输出。
总结:
1. 数组是使用下标来访问的,下标是从 0 开始。2. 数组的大小可以通过sizeof()计算得到。
int arr[10];
int sz = sizeof(arr)/sizeof(arr[0]);
4 .一维数组在内存中的存储
数组在内存中是连续存放的;
随着数组下标的增长,元素的地址也是增长的;
每放入一个int型元素,地址就增长4个字节(其他类型类似);
![](https://img-blog.csdnimg.cn/7748713d0b40437c92899baed2bc9772.png)
二、二维数组的创建和初始化
1. 二维数组的创建
//数组创建
int arr[3][4]; //创建一个3行4列的数组
char arr[3][5]; //创建一个3行5列的数组
double arr[2][4]; //创建一个2行4列的数组
2. 二维数组的初始化
//数组初始化
int arr[3][4] = {1,2,3,4}; //a[0][0]至a[0][3]:1至4
int arr[3][4] = {{1,2},{4,5}};
//创建二维数组的时候,行可以省略但列不能省略
int arr[][4] = {{2,3},{4,5}};
3. 二维数组的使用
二维数组也是通过下标的方式使用的。代码如下:
#include <stdio.h>
int main()
{
int arr[3][4] = {0};
int i = 0;
//初始化
//二维数组的行数
for(i=0; i<3; i++)
{
int j = 0;
//二维数组的列数
for(j=0; j<4; j++)
{
arr[i][j] = i*4+j;
}
}
//输出
for(i=0; i<3; i++)
{
int j = 0;
for(j=0; j<4; j++)
{
printf("%d ", arr[i][j]);
}
}
return 0;
}
4.二维数组在内存中的存储
以下通过画图的方式帮助大家更好的理解二维数组在内存中的存储:
![](https://img-blog.csdnimg.cn/f089acb494bb49ddbdc75b6e71e3ca55.jpeg)
三、数组地址相关的一些总结
int arr[10] = {1,2,3,4,5};
arr:数组第一个元素的地址,arr+1:数组第二个元素的地址;
&arr:整个数组的地址,&arr+1:跳过了整个数组(指向数组尾元素的下一个元素地址);
&arr[0]:数组首元素的地址,&[arr]+1:数组第二个元素的地址;
补充:
1. sizeof(
数组名
)
,计算整个数组的大小,
sizeof
内部单独放一个数组名,数组名表示整个数
组。
2. &
数组名,取出的是数组的地址。
&
数组名,数组名表示整个数组。
除此
1,2
两种情况之外,所有的数组名都表示数组首元素的地址。
注意:
数组传参时,若传的是arr,则传的数组首元素地址,在形参那里就不能用
sizeof(arr)计算整个数组的大小,因为形参是实参的一份临时拷贝(是一个地址),算出来的大小也只是一个地址的大小(32位4个字节);
若传的是&arr,则传的是整个数组的地址,可以在形参那用
sizeof(arr)计算整个数组的大小;