数据结构 数组存储地址的计算?

 我来答
帐号已注销
2021-01-15 · TA获得超过77.1万个赞
知道小有建树答主
回答量:4168
采纳率:93%
帮助的人:170万
展开全部

数组存储地址的计算:以二维数组为例,其他的依次类推:

假设起始下标从0开始,按行存储(总共有M行,N列):

A[i][j]=A[0][0]+(i*N+j)*L

这地方的L是数组中的一个元素所占的存储空间

例如:

第一个元素的地址“值”就是数组的地址“值”,只不过类型不一样,强转一下就可以了。

int ary[5];

int* pInt = &ary[0];

int (*pAry)[5] = &ary;

printf("First:\t%p\n", pInt);

printf("Array:\t%p\n", pAry);

扩展资料:

一个数组中的所有元素具有相同的数据类型(在C、C++、Java、pascal中都这样。但也并非所有涉及数组的地方都这样,比如在Visual Foxpro中的数组就并没这样的要求)。当然,当数据类型为 Variant 时,各个元素能够包含不同种类的数据(对象、字符串、数值等等)。可以声明任何基本数据类型的数组,包括用户自定义类型和对象变量。

参考资料来源:百度百科-数组

光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
ice58313dota
2017-12-22 · TA获得超过110个赞
知道答主
回答量:90
采纳率:100%
帮助的人:11万
展开全部
C语言特性的表达式是 *(a+i)+j
逻辑上来讲是 a的值(数组a的首地址值)加 (iN+j)*s N为最低维长度 s为数组元素长度
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
alwing
2012-06-25 · TA获得超过132个赞
知道小有建树答主
回答量:294
采纳率:0%
帮助的人:137万
展开全部
第一个元素,取地址
追问
然后呢
追答
第一个元素的地址“值”就是数组的地址“值”,只不过类型不一样,强转一下就可以了

int ary[5];
int* pInt = &ary[0];
int (*pAry)[5] = &ary;
printf("First:\t%p\n", pInt);
printf("Array:\t%p\n", pAry);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
屋石
推荐于2018-04-06 · TA获得超过5355个赞
知道大有可为答主
回答量:1909
采纳率:86%
帮助的人:928万
展开全部
数组存储地址的计算:以二维数组为例,其他的依次类推:
假设起始下标从0开始,按行存储(总共有M行,N列):
A[i][j]=A[0][0]+(i*N+j)*L
这地方的L是数组中的一个元素所占的存储空间
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式