1、二维数组逻辑结构和物理结构
逻辑结构:
在内存中的物理结构:
代码表示:
int arr[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
{
printf("%10d", &arr[i][j]);
}
printf("\n");
}
二、那麽如何表示二维数组的行和列呢?
每个绿框框表示一行那么由次推得:
每一行所占的字节数sizeof(arr[0])/sizeof(sizeof(arr[0][0]))
三、打印二维数组代码:
void My_printf(int (*arr)[4], int row, int col)
{
int i = 0, j = 0;
for (int i = 0; i < row; i++)
{
for (int j=0; j < col; j++)
{
printf("%d", arr[i][j]);
}
printf("\n");
}
}
int main()
{
int arr[3][4] = { {1,2},{3,4},{5,6} };
int row = sizeof(arr) / sizeof(arr[0]);
int col = sizeof(arr[0]) / sizeof(arr[0][0]);
My_printf(arr, row, col);
return 0;
}
知识补充:
1.数组指针:
int (*arr)[4]:p是一个指向整型数组的指针,简称数组指针,重点在于一定是个指针,数组起修饰作用
2. 指针数组:
int *arr[4]:是一个保存指针的数组
总结:
当遇到复杂的考虑两点
一.优先级 () >[ ]> *
二.1.若是指针(带*号),则看指向什么东西
2.若指向数组(带[]),则看长度和数据类型
3.若是函数(带小括号()),则看参数列表和访问值