如果我们需要编写一个处理二维数组的函数,那么这个函数原型应该如何声明呢?
首先,我们应该牢记:数组名被视为其地址,因此,相应的形参是一个指针。例如,假设有如下的代码:
int a[2][3]={{0,1,2},{3,4,5}};
fun(a);
一、在main函数打印
#include<stdio.h>
int main()
{
int a[2][3]={{0,1,2},
{3,4,5}};
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("a[%d][%d]=%d\n",i,j,a[i][j]);
}
return 0;
}
hcc@ubuntu:~/example$ ./a.out
a[0][0]=0
a[0][1]=1
a[0][2]=2
a[1][0]=3
a[1][1]=4
a[1][2]=5
二、直接用数组作形参
#include<stdio.h>
void fun(int a[2][3])
{
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("fun:a[%d][%d]=%d\n",i,j,a[i][j]);
}
}
int main()
{
int a[2][3]={{0,1,2},
{3,4,5}};
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("a[%d][%d]=%d\n",i,j,a[i][j]);
}
fun(a);
return 0;
}
#include<stdio.h>
void fun(int a[][3])
{
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("fun:a[%d][%d]=%d\n",i,j,a[i][j]);
}
}
int main()
{
int a[2][3]={{0,1,2},
{3,4,5}};
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("a[%d][%d]=%d\n",i,j,a[i][j]);
}
fun(a);
return 0;
}
hcc@ubuntu:~/example$ ./a.out
a[0][0]=0
a[0][1]=1
a[0][2]=2
a[1][0]=3
a[1][1]=4
a[1][2]=5
fun:a[0][0]=0
fun:a[0][1]=1
fun:a[0][2]=2
fun:a[1][0]=3
fun:a[1][1]=4
fun:a[1][2]=5
三、数组指针作形参传递
#include<stdio.h>
void fun(int (*a)[3],int n,int m)
{
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
printf("fun:a[%d][%d]=%d\n",i,j,a[i][j]);
}
}
int main()
{
int a[2][3]={{0,1,2},
{3,4,5}};
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("a[%d][%d]=%d\n",i,j,a[i][j]);
}
fun(a,2,3);
return 0;
}
hcc@ubuntu:~/example$ ./a.out
a[0][0]=0
a[0][1]=1
a[0][2]=2
a[1][0]=3
a[1][1]=4
a[1][2]=5
fun:a[0][0]=0
fun:a[0][1]=1
fun:a[0][2]=2
fun:a[1][0]=3
fun:a[1][1]=4
fun:a[1][2]=5
四、利用数组是顺序存储的特性, 通过降维来访问原数组!
#include<stdio.h>
void fun(int *a,int n,int m)
{
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
// printf("fun:a[%d][%d]=%d\n",i,j,*(a+m*i+j));
printf("fun:a[%d][%d]=%d\n",i,j,a[m*i+j]);
}
}
int main()
{
int a[2][3]={{0,1,2},
{3,4,5}};
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
printf("a[%d][%d]=%d\n",i,j,a[i][j]);
}
fun((int*)a,2,3);
return 0;
}