二维数组知识点:
定义及初始化:
int a[2][3] = {{1, 2, 3} , { 4, 5, 6}}; 一个两行三列的数组;使用两层括号
int a[2][3] = {{1 ,2 } ,{4, 5}}; 若某些数组元素未知,则未知元素自动变为0
int a[ ][3] = {{1, 2, 3} , { 4, 5, 6}}; 定义二维数组时,可不写行数,但必须写列数
二维数组使用重点总结:
int a[n][m] ={{ }, { }} : 表示一个n+1行,m+1列的二维数组
a[n][m] : 表示第n+1行,第m+1列的数, &a[n][m]表示它的地址
a[0] : 表示首行首元素的地址,*a[0]表示首行首元素的值
a:表示首行的地址 = &a[0]
&a: 表示整个数组的地址(和一维数组一样)
a 是二维数组名。a 数组包含 2行,即 2 个行元素:a[0],a[1]。每个行元素都可以看成含有 3个元素的一维数组。而且 C 语言规定,a[0]、a[1]分别是这两个一维数组的数组名。
数组名表示这个数组的首元素地址,a[0]是第一个一维的数组名(第一行),也就是第一行的首元素的地址。 对a[0]这个地址再取地址,就是变成了这一行的地址。 &a表示整个数组的地址,这个和一维数组一样。地址加1:按照数组内数据类型自动换算成字节,如果int数组元素取地址后加一,实际地址加上四个字节。若为char型取地址后加1,则实际地址加上一个一个字节。
总结:&a > a > a[ ] = a[ ][0]
一句话记住就是取地址就是向外走,取元素就是向里走。
(当我想明白这件事情时,心里是欣喜若狂的,恨不得告诉全世界) *^*
程序如下:
#include <stdio.h>
int main(){
printf("\n----------二维数组-----------\n");
//int a[2][3] = {{1, 2, 3},{ 4, 5, 6}};
int a[][3] = {{1, 2, 3},{ 4, 5, 6}};
//int a[2][3] = {{1, 2},{ 4, 5}};
int i,j;
for(i =0; i< 2; i++)
{
for(j = 0; j < 3; j++)
{
printf("%d ",a[i][j]);
}
printf("\n");
}
printf("\n----------未加1以前的地址和值-----------\n");
printf("&a[0][1] %p %d\n", &a[0][1],a[0][1]);
printf("a[0] %p %d\n", a[0] , *a[0]);
printf("a %p\n", a);
printf("&a[0] %p\n", &a[0]);
printf("&a %p\n", &a);
printf("\n-----------加1以后的地址和值-----------\n");
printf("&a[0][1]+1 %p %d\n", &a[0][1]+1, a[0][1]+1 );
printf("a[0]+1 %p %d\n", a[0]+1, *(a[0]+1));
printf("a+1 %p\n", a+1);
printf("&a[0]+1 %p\n", &a[0]+1);
printf("&a+1 %p\n", &a+1);
return 0;
}