刷题刷出新高度,偷偷领先!偷偷领先!偷偷领先! 关注我们,悄悄成为最优秀的自己!

单选题

数组元素a[i,j](其中i和j满足特定范围)在行优先存储方式下的偏移量是多少?

A
(j*m+i)*4    
B
(i*m+j)*4    
C
(j*n+i)*4    
D
(i*n+j)*4 
使用微信搜索喵呜刷题,轻松应对考试!

答案:

B

解析:

数组元素a[i,j](0≤i<n,0≤j<m)以行为主序存放,意味着数组元素在内存中的排列顺序是按照行优先的顺序进行的。因此,在计算数组元素a[i,j]的存储位置相对于数组空间首地址的偏移量时,需要先计算它在当前行中的位置,然后再计算它在整个数组中的位置。

在行优先的存储方式下,第i行的元素个数是m,因此在a[i,j]前面的元素个数为i * m。再加上本行前面的j个元素,总共前面的元素个数为i * m + j。由于每个元素占用4个存储单元,所以a[i,j]相对数组空间首地址的偏移量为(i * m + j) * 4。

根据选项对比,选项D(i*n+j)*4中的表达式与上述计算相符,因此D是正确答案。

创作类型:
原创

本文链接:数组元素a[i,j](其中i和j满足特定范围)在行优先存储方式下的偏移量是多少?

版权声明:本站点所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明文章出处。

让学习像火箭一样快速,微信扫码,获取考试解析、体验刷题服务,开启你的学习加速器!

分享考题
share