| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1102 人关注过本帖
标题:请教数组在内存中地址问题
取消只看楼主 加入收藏
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
快速回复:请教数组在内存中地址问题
数据加载中...
 
   



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

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