首先我们要搞清楚这个数组从00开始还是11开始,他们对应了两种不同情况。
1.从00开始
行标从0到m-1,列标从0到n-1,则对于数组A来说是A[m][n],求A[i][j]
1.1按行存放
套用公式:SA(起始地址)+[ i * (n) + j ] * size
1.2按列存放
套用公式:SA + [ j * (m) + i ] * size
例题:二维数组A中,每个元素A的长度为3个字节,行下标i从0到7,列下标j从0到9,从首地址SA开始连续存放在存储器内,该数组按列存放时,元素A[4][7]的起始地址为()。提示:是按列存放。
分析:从00开始,且按列存放,行标0~7,列标0~9,则A[8][10]
SA + (7 * 8 + 4) *3 = SA + 180
2.从11开始
行标从1到m,列标从1到n,则对于数组A来说是A[m][n],求A[i][j]
2.1按行存放
套用公式:SA(起始地址)+[ i * (n-1) + j-1 ] * size
2.2按列存放
套用公式:SA + [ j * (m-1) + i-1 ] * size
或者可以看作是:
在这种情况下求A[i][j] 就是在求A[i-1][j-1]
然后再套用上面1的公式 SA +( (i-1) * n + (j-1) ) * size 从而更容易记