1.函数之间参数传递的方式有___值传递_____和__地址传递______。(富士安全)
2.简述:函数之间两种参数传递方式的区别。
值传递只改变函数内部的形参,而对于主函数中的实参的值没有任何影响,如果是地址传递,可以通过改变形参的地址直接改变实参的地址从而改变实参的值
3.函数main 有那些参数?各代表什么含义? 假如程序a调用如下所示:a 123写出程序a中main 函数的参数的具体值。 (拓仓科技)
argc和argv,argc表示的是这次命令的参数个数,不会为0,因为函数名也是一个参数,argv是一个指针数组,如果是a 123,argc是2,一个是‘a’一个是‘123’,而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 man_fun(int n,int *p,int *max);
void min_fun(int n,int *p,int *min);
int main(int argc, const char *argv[])
{
int a[]={11,8,89,7,5,4,32,15,21},max,min;
man_fun(9,a,&max);
min_fun(9,a,&min);
printf("最大值是%d\n最小值是%d\n",max,min);
return 0;
}void man_fun(int n,int *p,int *max){
for(int i=0;i<n;i++){
if(*(p+i)>*max){
*max=*(p+i);
}
}
}
void min_fun(int n,int *p,int *min){
for(int i=0;i<n;i++){
if(*(p+i)<*min){
*min=*(p+i);
}
}
}
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 input_fun(int (*p)[4],int hang,int lie);
void output_fun(int (*p)[4],int hang,int lie);
void max_fun(int (*p)[4],int hang,int lie);
int main(int argc, const char *argv[])
{
int a[3][4];
input_fun(a,3,4);
output_fun(a,3,4);
max_fun(a,3,4);
return 0;
}void input_fun(int (*p)[4],int hang,int lie){
int count=1;
for(int i=0;i<hang;i++){
for(int j=0;j<lie;j++){
int x=1;
printf("请输入%d个数字:",count);
scanf("%d",*(p+i)+j);
count++;
}
}
}
void output_fun(int (*p)[4],int hang,int lie){
for(int i=0;i<hang;i++){
for(int j=0;j<lie;j++){
printf("%d ", *(*(p+i)+j));
}
}
}
void max_fun(int (*p)[4],int hang,int lie){
int max=p[0][0];
for(int i=0;i<hang;i++){
for(int j=0;j<lie;j++){
if(*(*(p+i)+j)>max){
max=*(*(p+i)+j);
}
}
}
printf("最大值