![c2031988db57e73ab593247e89870e8f.png](https://i-blog.csdnimg.cn/blog_migrate/c7e110ae5742e5f9b19d3fd8dffd2118.jpeg)
一、二维数组的行地址和列地址
在C语言中可将一个二维数组看成由若干一维数组构成。若有下面的定义语句:
int a[3][4];
则其二维数组的逻辑结构如图
![7e02b4cfc12f68a78cf222d6da46c450.png](https://i-blog.csdnimg.cn/blog_migrate/57fa7e836e9905b5f097f21bb0ad7157.jpeg)
二维数组a的逻辑机构 图一
首先,可将二维数组a看成是由a[0]、a[1]、a[2]三个元素组成的一维数组(图一所示),a是该一维数组的数组名,代表该一维数组的首地址,即第一个元素a[0]的地址(&a[0])。根据一维数组与指针的关系可知,表达式a+1表达首地址所指元素后面的第一个元素的地址,即a[1]的地址(&a[1])。同理,表达式a+2表示a[2]的地址(&a[2])。可通过这些地址引用元素的值,如*(a+2)或*a即为a[0],*(a+1)即为a[1],*(a+2)即为a[2]。
注意:这里所指的元素a[0]、a[1]、a[2]事实上仍然是个地址。