1、函数之间参数传递的方式有_______和________。
答: 值传递 地址传递
2、简述:函数之间两种参数传递方式的区别。
答:值传递传递时,相当于实参复印了一份复印件,然后把复印件传给了形参,实参原值不改变;而地址传递在传递时实参直接将自身传递给形参。
3、函数main 有那些参数?各代表什么含义? 假如程序a调用如下所示:a 123写出程序a中main 函数的参数的具体值。 (拓仓科技)
答:有argc 与*argv[ ]两个参数
argc表示用于存放命令行参数的个数
*argv[ ]表示显示命令行中输入的参数
①argc=2
②argv[0]=”a“
argv[1]="123"
4、用指针作函数参数,编程序求一维数组中的最大和最小的元素值
思路:①主函数中定义一维数组int a[]={11,8,89,7,5,4,32,15,21} , max , min;
②定义函数 void arr_max(int *a, int n,int *max); //a接收数组 n表示长度 max接收最大值
③定义函数 void arr_min(int *a, int n,int *min); //a接收数组 n表示长度 min接收最小值
④在主函数中输出最大值和最小值
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void arr_max(int *a,int n,int *max);//声明函数
void arr_min(int *a,int n,int *min);//声明函数int main(int argc, const char *argv[])
{
int a[]={11,8,89,7,5,4,32,15,21};
int max;
int min;
//定义数组
int len=sizeof(a)/sizeof(int);
arr_max(a,len,&max);
arr_min(a,len,&min);
printf("\n");
return 0;
}void arr_max(int *a,int n,int *max){
*max=*a;
for(int i=0;i<n;i++){
if(*max<*(a+i)){
*max=*(a+i);
}
}
printf("max=%d\n",*max);}
void arr_min(int *a,int n,int *min){
*min=*a;
for(int i=0;i<n;i++){
if(*min>*(a+i)){
*min=*(a+i);
}
}
printf("min=%d\n",*min);
}
5、用指针接收函数参数,编程序求二维数组的输入、输出、求最大值
思路:1》主函数中定义二维数组 int a[3][4];
2》自定义函数void arr_input(int (*a)[4] , int H , int L);
3》自定义函数void arr_output(int (*a)[4] , int H , int L);
4》自定义函数void arr_max(int (*a)[4] , int H , int L);
5》主函数调用函数实现
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void a_input(int (*a)[4],int h,int l);
void a_output(int (*a)[4],int h, int l);
int a_max(int (*a)[4],int h,int l,int *max);
int main(int argc, const char *argv[])
{
int a[3][4];
int max;
a_input(a,3,4);
a_output(a,3,4);
printf("max=%d\n",a_max(a,3,4,&max));
return 0;
}
void a_input(int (*a)[4],int h,int l){
printf("请输入%d行%d列:\n",h,l);
for(int i=0;i<h;i++){
for(int j=0;j<l;j++){
scanf("%d",*(a+i)+j);
}
}
}
void a_output(int (*a)[4],int h, int l){
printf("输出:\n");
for(int i=0;i<h;i++){
for(int j=0;j<l;j++){
printf("%5d",*(*(a+i)+j));
}
printf("\n");
}
}
int a_max(int (*a)[4],int h,int l,int *max){
*max=a[0][0];
for(int i=0;i<h;i++){
for(int j=0;j<l;j++){
if(*max<*(*(a+i)+j)){
*max=*(*(a+i)+j);
}
}
}
return *max;
}