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.若是函数(带小括号()),则看参数列表和访问值
本文详细介绍了二维数组的逻辑结构和在内存中的物理存储方式,通过实例展示了如何用C语言表示和打印二维数组。同时,讨论了数组行和列的表示,并提供了相关代码。此外,还讲解了数组指针的概念,强调了指针、数组和函数调用时的优先级和解析规则。
1万+

被折叠的 条评论
为什么被折叠?



