请教数组在内存中地址问题
对于一个m行、n列的二维数组num,num[i][j](i≤m,j≤n)在内存中的地址应为:num+i×n+j怎么理解啊?请教?
[此贴子已经被风中涟漪于2004-11-05 16:57:32编辑过]
num是数组首地址,即num[0][0]的地址,后面的是后移多少位,
i×n+j 中的一行j的长度是n,而每下一行就i加一,如下:
1 2 3 4 5 6 7 8 9 10 1□□□□□□□□□□ 2□□□□□□□□□□ 3□□□□□□□□□□ 4□□□□□□□□□□ 5□□□□□□□□□□ 6□□□□□□□□□□ 7□□□□□□□□□□ 8□□□□□□□□□□ 9□□□□□□□□□□ 10□□□□□□□□□□
每一行是 i ,每一列是 j ,你自己想想这个逻辑关系吧。
[此贴子已经被作者于2004-11-02 10:22:46编辑过]
num是数组首地址,num[0][0]的地址,后面的是后移多少位,
i×n+j 中的一行j的长度是n,而每下一行就i加一,如下:当 I=0,J=0 时,公式 I X N +J =0,那么表示移动 零位,当 I 还是 0(即还是第一行时)此时 J +1 ,公式结果为 1,那么表示移动 一位 ,表示为 num[0][1],指向同一行的下一列;是不是也可以这样认为:数组定义为 int num[10][10] 那么 数组将包含100个元素,公式得到的结果就代表着现在是指向的是第几位元素;
0 1 2 3 4 5 6 7 8 9 0□□□□□□□□□□ 1□□□□□□□□□□ 2□□□□□□□□□□ 3□□□□□□□□□□ 4□□□□□□□□□□ 5□□□□□□□□□□ 6□□□□□□□□□□ 7□□□□□□□□□□ 8□□□□□□□□□□ 9□□□□□□□□□□