一维数组和二维数组的声明和它们作为函数参数的写法
前几天自己做题时遇见了数组作为函数参数和使用n个数字参与操作的题,申请大小为n的数组,n由用户定义,我自己写下自己的收获
一维数组和二维数组的声明
1.1一维数组的声明
一维数组例如:
int a[10];
char str[10];
这样写声明一个大小为10的整形数组数组名为a和申请一个大小为10的字符型数组数组名为str,如果你先声明一个数组,大小由自己输入,这样写就不行了。那么,我们可以试试这样写:
使用malloc,calloc添加头文件#include”
在动态申请空间时,我发现使用malloc和calloc区别不大,malloc申请一块大小为n*sizeof(该类型大小)的空间,申请的空间未初始化;而使用calloc申请一块连续的n个大小为sizeof(该类型)的空间,并将这个新申请开辟空间内所有数据初始化为0,整形为0,字符型为’\0’。
1.2二维数组的声明
例如:
int a[5][5];
char str[3][10];
声明一个整形的二维数组,五行五列;
声明一个二维字符型数组,三行,每行十个单位大小;
如果使用calloc定义,则可以这样写:
int *a[5],i;//首先申请一个int型指针数组,数组中5个int型指针
for(i=0;i<4;i++)
a[i]=(int *)calloc(n,sizeof(int));//分别给每个指针数组中的元素分配空间;
一维数组和二维数组作为函数参数
2.1一维数组作为函数参数
使用a[10],和malloc的*a没有区别,因为一维数组做函数参数时本来就传递的是数组的地址,是个指针类型的参数,指向数组首地址。
例如:求最大值的题:
#include"stdio.h"
int max(int *a);
int main()
{
int a[5];
int i,MAX;
printf("请输入五个数字求最大值:\n");
for(i=0;i<5;i++)
scanf("%d",&a[i]);
MAX=max(a);
printf("最大值:%d\n",MAX);
return 0;
}
int max(int *a)
{
int i,m=0;
for(i=0;i<5;i++)
if(m<a[i])
m=a[i];
return m;
}
或者这样写:
#include"stdio.h"
#include"stdlib.h"
int max(int *a);
int main()
{
int *a;
a=(int*)calloc(5,sizeof(int));
printf("请输入五个数字求最大值:\n");
for(i=0;i<5;i++)
scanf("%d",&a[i]);
MAX=max(a);
printf("最大值:%d\n",MAX);
return 0;
}
int max(int *a)
{
int i,m=0;
for(i=0;i<5;i++)
if(m<a[i])
m=a[i];
return m;
}
2.2二维数组作为函数参数
二维数组作为函数的参数时,因为二维数组在本质上是一个二级指针,也就是**p,它做函数参数的写法有两种:
A:
函数类型 函数名(数据类型 [][N]);
例:
#include<stdio.h>
#define N 5
#define M 3
//这是一个求最大值的函数
int MAX(int num[][N]); //用N来表示二维数组的列数
int main()
{
int num[M][N];
int i,j,max;
for(i=0;i<M;i++)
for(j=0;j<N;j++)
scanf("%d",&num[i][j]);
max=MAX(num);
printf("最大值为%d\n",max);
return 0;
}
int MAX(int num[][N])
{
int i,j,t=0;
for(i=0;i<M;i++)
for(j=0;j<N;j++)
if(t<num[i][j])
t=num[i][j];
return t;
}
B:
函数类型 函数名(数据类型 **p);
例:
#include<stdio.h>
#include<stdlib.h>
#define N 5
#define M 3
//这是一个求最大值的函数
int MAX(int **num); //用N来表示二维数组的列数
int main()
{
int *num[M];//申请一个指针数组
int i,j,max;
for(i=0;i<M;i++)
num[i]=(int *)calloc(N,sizeof(int));//给其中的每个指针指向一段可存储的空间
for(i=0;i<M;i++)
for(j=0;j<N;j++)
scanf("%d",&num[i][j]);
max=MAX(num);
printf("最大值为%d\n",max);
return 0;
}
int MAX(int **num)
{
int i,j,t=0;
for(i=0;i<M;i++)
for(j=0;j<N;j++)
if(t<num[i][j])
t=num[i][j];
return t;
}