标题:请教数组在内存中地址问题
取消只看楼主
reso
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2004-11-2
 问题点数:0 回复次数:1 
请教数组在内存中地址问题
对于一个m行、n列的二维数组num,num[i][j](i≤m,j≤n)在内存中的地址应为:num+i×n+j怎么理解啊?请教?

[此贴子已经被风中涟漪于2004-11-05 16:57:32编辑过]

搜索更多相关主题的帖子: 内存 num 地址 
2004-11-02 09:26
reso
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2004-11-2
得分:0 

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□□□□□□□□□□

2004-11-02 11:23



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-6939-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.142554 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved