一:数组元素作为函数的实参

数组元素就是变量,与普通变量没有区别,将数组元素传送给形参,实现单向的值传递。

#include <stdio.h>
float max(float x,float y){
	if(x > y)
	return x;
	else
	return y;
}
int main(){
	int a[6] = {3,2,1,4,9,0};
	int m = a[0];
	for(int i = 1;i < 6; i ++){
		m = max(m,a[i]);
	}
	printf("数组中的最大元素是:%d",m);
}

二:数组名作为函数的实参

实质是地址的传递,将数组的首地址传给形参,形参和实参共用同一存储空间,形参的变化就是实参的变化。

#include <stdio.h>
void sort(int b[],int n){
	for(int i = 0; i < n - 1; i ++)
	for(int j = 0; j < n-i-1; j ++)
	if(b[j] > b[j+1]){
		int temp;
		temp = b[j];
		b[j] = b[j+1];
		b[j+1] = temp;
	}
}
int main(){
	int a[10];
	printf("请输入数组的元素:");
	for(int i = 0;i < 10; i ++){
		scanf("%d",&a[i]);
	}
	printf("排序后的数组顺序是:");
	sort(a,10);
	for(int i = 0; i < 10;  i++){
		printf("%d ",a[i]);
	}
} 

三:二维数组名作为函数参数

第一维的大小可以不指定,第二维的大小必须指定。实参传送的是二维数组的首地址,使得二维数组a与b共用同一存储单元,即a[0][0]与b[0][0]共用同一存储单元,a[0][1]与b[0][1]共用同一存储单元。

#include <stdio.h>
//b[3][4]也正确
int max(int b[][4]){
	int max1 = b[0][0];
	for(int i = 0; i < 3; i ++)
	for(int j = 0; j < 4; j ++)
	if(b[i][j] > max1){
	max1 = b[i][j];
    }
	return max1;
}
int main(){
	int a[3][4] = {5,16,30,40,23,4,123,8,1,3,50,37};
	int m = max(a);
	printf("max is %d", m);
}

 

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐