C语言怎么定义max函数?
main()
{
int x,y,z;
printf("input two numbers:\n");
scanf("%d%d",&x,&y);
z=max(x,y);
printf("maxnum=%d",z);
getch();
}
未定义的符号 '_max' 在模块 noname.c 展开
max函数用于求最大值,可以定义如下函数:
int max(int a, int b)
{
if(a>b) return a;
return b;
}
不过该函数只能用于整型而不能用于其它类型。如果有其它类型,比如浮点型,则需要再重新修改。
float max(float a , float b)
{
if( a > b) return a;
return b;
}
其实这样代码量比较少的操作,可以定义为宏函数,即带参宏定义的形式。
#define max(a,b) ((a)>(b)?(a):(b))
这样既可以不受参数类型限制,又可以提高执行效率。
不过从你的代码来看,只需要定义int类型的max函数即可。
扩展资料:
max(x,y)=0.5*(x+y+|x-y|);在概率论中多有使用,可以将参数指定为数字、空白单元格、逻辑值或数字的文本表达式。如X、Y独立同分布,X~N(0,1),求期望E(max(x,y))。
参考资料来源:百度百科-max函数
max函数用于求最大值,可以定义如下函数。
int max(int a, int b)
{
if(a>b) return a;
return b;
}
不过该函数只能用于整型而不能用于其它类型。如果有其它类型,比如浮点型,则需要再重新修改。
其实这样代码量比较少的操作,可以定义为宏函数,即带参宏定义的形式。#define max(a,b) ((a)>(b)?(a):(b))
这样既可以不受参数类型限制,又可以提高执行效率。
扩展资料
c语言
C语言是一门通用计算机编程语言,广泛应用于底层开发。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。 目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准,该标准更好的支持了汉字函数名和汉字标识符,一定程度上实现了汉字编程。
C语言是一门面向过程的计算机编程语言,与C++,Java等面向对象的编程语言有所不同。
其编译器主要有Clang、GCC、WIN-TC、SUBLIME、MSVC、Turbo C等。
int max(int a, int b)
{
if(a>b) return a;
return b;
}
不过该函数只能用于整型而不能用于其它类型。如果有其它类型,比如浮点型,则需要再重新修改。
其实这样代码量比较少的操作,可以定义为宏函数,即带参宏定义的形式。
#define max(a,b) ((a)>(b)?(a):(b))
这样既可以不受参数类型限制,又可以提高执行效率。
// 在你的代码后面加上:
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();
}
程序改成这样 :
int max(int a,int b);
main()
{
int x,y,z;
printf("input two numbers:\n");
scanf("%d%d",&x,&y);
z=max(x,y);
printf("maxnum=%d",z);
getch();
}
int max(int a,int b) //函数要先定义再使用
{if(a>b)
max=a;
else
max=b;
}