指针与二维数组
多维数组就是具有两个或两个以上下标的数组
在C语言中,二维数组的元素连续存储,按行优先存
编程实现,使用一级指针遍历二维数组
#include <stdio.h>
int main(int argc, char *argv[])
{
int a[3][2] = {{1, 6}, {9, 12}, {61, 12}};
int * p, i, n;
n = sizeof(a) / sizeof(int);
p = a[0]; //&a[0][0];
printf("%p %p\n", p, p+1);
printf("%p %p\n", a, a+1);
for (i = 0; i < n; i++)
printf("%d ", *(p+i));
puts("");
return 0;
}
可把二维数组看作由多个一维数组组成。
比如int a[3][3],含有三个元素:a[0]、a[1]、a[2]
元素a[0]、a[1]、a[2]都是一维数组名
二维数组名代表数组的起始地址,数组名加1,是移动一行元素。因此,二维数组名常被称为行地址
行指针(数组指针)
行指针(数组指针)
存储行地址的指针变量,叫做行指针变量。形式如下:
<存储类型> <数据类型> (*<指针变量名>)[表达式] ;
例如,int a[2][3]; int (*p)[3];
方括号中的常量表达式表示指针加1,移动几个数据。
当用行指针操作二维数组时,表达式一般写成1行的元素个数,即列数。
二维数组名有什么特点?
编程实现,使用行指针遍历二维数组?
#include <stdio.h>
int main(int argc, char *argv[])
{
int a[3][2] = {{1, 6}, {9, 12}, {61, 12}};
int (*p)[2], i, j;
p = a;
printf("%p %p\n", a, a+1);
printf("%p %p\n", p, p+1);
//printf("%d, %d, %d, %d\n", a[1][1], p[1][1], *(*(a + 1)+1), *(*(p + 1) + 1));
for (i = 0; i < 3; i++) {
for (j = 0; j < 2; j++)
printf("%d, %d, %d, %d ", a[i][j], p[i][j], *(*(a + i)+j), *(*(p + i) + j));
puts("");
}
return 0;
}