第四章 c数组

数组的概念

若干个相同类型的变量在内存中有序存储的集合。
数组在内存中是连续存储的。

数组的分类

按元素的类型分类

char a[10];
short a[10];
int a[10];
long int a[10];
int *a[10];
struct stu boy[10];

按维度分类

int a[10];
int b[1][2];
int c[1][2][3];
int d[1][2][3][4];

数组的定义和访问

定义

//数据类型  数组名 [元素的个数];
int             a          [10];
//或者
int a[] = {1,2,3};

访问

使用下标访问,从0开始;
int a[10];
从a[0]到a[9];

二维数组的定义

int a[4][5];
int a[][3] = {{1,2,3},{1,2,3}}

数组的初始化

int [1];
a[0] = 1;
//或者定义的时候初始化,后面元素可以不写,默认为0
int [3] = {1};
//二维数组
int a[2][2];
a[0][0] = 1;
//可以不写行
int b [][3] = {{1,2,3}, {1,2,3}};
//int b[2][3] = {1,2,3,4,5,6}等价于 int b[2][3] = {{1,2,3},{4,5,6}}
//三位数组
int c[][][4] = {
{{1,2,3,4},{1,2,3,4}}
};

字符数组

char a[] = {'h', 'e', 'l', 'l', 'o'};
char b[] = {"hello"};
printf("%s\n", b)

使用字符串方式赋值会比字符逐个赋值多占1个字节。‘\0’是由编辑系统自动加上的。
实际内存中:
第四章 c数组_第1张图片

你可能感兴趣的:(c,c语言,java,算法)