考虑2D阵列"阵列"包含值:{1,2,3,4,5,6,7,8,9}。理解这两个订单的主要问题是如果要将行主要顺序表示为数组[i,j](而我是行而j是列),
[i0,j0][i0,j1][i0,j2]
[i1,j0][i1,j1][i1,j2]
[i2,j0][i2,j1][i2,j2]
因此,如果你被问到像#34这样的问题,在数组[2] [2]"中找到元素数组[1,2]的地址,你就知道了行数在列数之前,并且很容易将它们放在公式中:
Base(Address) + w(dataSize){N(i - Row_lowerBound)+(j - Col_lowerBound)}
While 'N' is the number of columns
是否意味着列顺序可以表示为Array [j,i],这意味着列号显示早于行号。因此,无法知道将Array [j] [i](例如Array [3] [4])的i,j,Row_lowerbound和Col_lowerbound值放在公式中的位置。
例如,如果问题显示为:"在数组Array [3] [4]"中找到Array [1] [2]的地址。你怎么知道3是colmns还是4?你怎么知道' i'是3还是4?
答案 0 :(得分:0)
你无法知道。计算机如何表示数据与您如何解释数据之间没有关系。由于您“ free ”以您喜欢的方式解释它,因此您有责任知道哪个索引用于行,哪个索引用于列。
通常,您可以在代码本身的注释中编写规范,或者使用该结构编写函数的文档。此外,您可以编写函数来访问强制执行索引顺序的数组。但是,它仍然没有立即明确,但有一个好处,你可以检查越界访问。