形参与实参的区别:
高级语言在设计程序模块时,模块名定义后,紧跟其后所定义的参数(括弧内)被称为形参(也称虚参)。当该模块被调用时,在主调模块中,出现在被调用的模块名后的参数被称为实参。实参代替虚参的过程被称为虚、实结合,也称换参。多数高级语言的换参是由编译系统来完成,比如C语言和FORTRAN语言亦是如此。BASIC语言的换参则是由程序设计人员来完成的。如果只允许实参向虚参传递,则被称为“单向传递”,C语言的变量类虚、实结合即是“单向传递”。如果同时允许虚参向实参传递,这种传递被称为“双向传递”,FORTRAN 语言定义的子程序即是如此。 当C语言的形参为数组时,形参不另辟存储单元,形参与实参共用内存存储单元。这样,可以节省内存。 C语言在定义函数的同时,对于有参函数,也同时定义了形参。在调用该函数的同时,也指明了实参。实参与形参在内存分别占有两套不同的存储单元(数组除外),但是形参只有在函数被调用过程中才分配存储单元,调用结束后形参占用的单元被释放。数组元素作为实参时,也做为变量来处理。
1、max函数不是一个C语言里提供给的函数,而是程序员自己定义的。一般来说,max函数是用来求一组数据中的最大值。
2、例如:
int max(int a,int b){
if (a>b)
return a
else
return b
}
// 或者用更简单的:
int max(int a,int b)
{
return a>b?a:b
}
//或者使用宏定义:
#define MAX(a,b) (a>b)?(a):(b)
main()
{
int x,y,z,max
printf("input two numbers:\n")
scanf("%d%d",&x,&y)
z=MAX(x,y)
printf("maxnum=%d",z)
getch()
}
#include<stdio.h>int main()
{ float max(float x, float y)
float a[4], t, u, v
int i
for (i = 0i <= 3i++)
{ printf("请输入第%d个数字:", i + 1)
scanf("%f", &a[i])
}
t = max(a[0],a[1] )
u = max(a[2], a[3])
v = max(t, u)
printf("前两个数中最大的是%f", t)
printf("后两个数中最大的是%f", u)
printf("四个数中最大的是%f", v)
return 0
}
float max(float x, float y) //这一行多了""
{ return(x >y ? x : y)
}