ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

二维数组 A[m][n] 按行优先和按列优先的 下标地址转换公式

2021-05-30 10:05:35  阅读:209  来源: 互联网

标签:Loc 优先 下标 元素 按列 按行


设二维数组 A[m][n] 按行优先存储, 每个元素占 p 个字节,

  则 Loc(i, j) 的地址为 (i * n + m) * p, 第 i 行前面有 i 行, 每行有 n 个元素, 加上 第 i 行的的 j 个元素,所以地址 为 (i * n + m) * p,

  1. 若 j 从下标 1 开始, 则 Loc(i, j) = (i * n + j - 1)

     第 i 行的 第 j 个元素,在第 i 行中 前面只有 j  - 1 个元素,

  2. 若 i 从下标 1开始, 则 Loc(i, j) = ((i - 1) * n + j)

  3. 若 i, j 均从 下标 1 开始, 则 Loc(i, j) = ((i - 1) * n + j - 1)

若该数组按列优先存储,

  则 Loc(i, j) 为  (j * m + i) * p, 第 j  列前面有 j 列,每列有 m 个元素, 加上 第 j 列的 i 个元素,所以为 (j * m + i) * p

  1. 若 j 从下标 1 开始, 则 Loc(i, j) = ((j - 1) * m + i);

    因为 第 j 列前面只有  (j - 1) 列

  2. 若 i 从下标 1开始, 则 Loc(i, j) = (j * m + i - 1)

    第 i 个元素前面实际上只有 i - 1 个元素

  3. 若 i, j 均从 下标 1 开始, 则 Loc(i, j) = ((j - 1) * n + i - 1)

 

总结:

  按行优先 Loc(i, j) = (i * n + j) * p, 按列优先 Loc(i, j) = (j * m + i) * p, 行从下标1 开始  i 就减一, 列从下标 1 开始 , j 就减一

  

标签:Loc,优先,下标,元素,按列,按行
来源: https://blog.51cto.com/u_14201949/2832536

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有