二维数组的定义和遍历
#include <stdio.h>
int array[2][2] = {{1,2},{3,4}};
int main()
{
int i,j;
for(i=0;i<2;i++){
for(j=0;j<2;j++){
printf("%d ",array[i][j]);
printf("address:%p ",&array[i][j]);
}
putchar('\n');
}
return 0;
}
例子:有一个3x4的矩阵,要求编程求出其中的最大值元素,以及其所在的行列号
#include <stdio.h>
int array[3][4] = {{1,2,47,8},{3,4,2,9},{3,5,9,0}};
int main()
{
int Max;
int hang,lie;
int i,j;
Max = array[0][0];
for(i=0;i<3;i++){
for(j=0;j<4;j++){
if(Max < array[i][j]){
Max = array[i][j];
hang = i;
lie = j;
}
}
}
printf("Max=%d\n",Max);
printf("%d行%d列\n",hang,lie);
return 0;
}
二维数组地址的认知
1.数组名就是地址
2.二维数组本质还是数组,不同点就是数组元素还是个数组(子数组)
3.a[0] 既是一维数组名,也是该数组的a[0]中第0列元素的地址,即&a[0][0],也就是说例如a[1]的值是&a[1][0]
关于二维数组地址的偏移
#include <stdio.h>
int main()
{
int arr[3][4] ={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
printf("arr是父亲地址:%p,偏移1后的地址:%p\n",arr,arr+1);
printf("arr[0]是子数组的地址:%p,偏移1后的地址是:%p %d %d\n",arr[0],arr[0]+1,*arr[0],*arr[0]+1);
printf("arr[0]是子数组地址:%p,偏移1后的地址:%p",*(arr+0),*(arr+0)+1);
return 0;
}
二维数组的遍历
#include <stdio.h>
int main()
{
int i,j;
int arr[3][4] ={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
for(i=0;i<3;i++){
for(j=0;j<4;j++){
printf("add:0x%p,data:%d\n",&arr[i][j],arr[i][j]);
printf("add:0x%p,data:%d\n",arr[i]+j,*(arr[i]+j));
printf("add:0x%p,data:%d\n",*(arr+i)+j,*(*(arr+i)+j));
}
}
return 0;
}
指针偏移的方法
#include <stdio.h>
int main()
{
int i,j;
int arr[3][4] ={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
int *p;
p = &arr[0][0];
for(i=0;i<3;i++){
for(j=0;j<4;j++){
printf("address:%p,data:%d\n",p,*p);
p++;
}
}
return 0;
}