inta[]={15,62,38,97,45};//定义一个十个数据的数组
intmax;//存放最大值
intmin;//存放最小值
hanshu(a,10&max,&min);//函数传送数组并将最大值,最小值的地址传送
#include命令预处理命令的一种预处理命令可以将别的源代码内容插入到所指定的位置;可以标识出只有在特定条件下才会被编译的某一段程序代码;可以定义类似标识符功能的宏,在编译时预处理器会用别的文本取代该宏。
#include命令告诉预处理器将指定头文件的内容插入到预处悝器命令的相应位置有两种方式可以指定插入头文件:
专业C/C++软件开发
1 函数参数设计:数组首地址(指针),数組长度(int),最大值及最小值(两个指针)
2 以第一个数为最大/最小值。
3 遍历其余数与最大/最小值比较,如果更大/小则替换该值。
当遍历结束則得到最大及最小值。
本回答被提问者和网友采纳
在实践中请大家最好按照 的回答去定义。
我来说个道理知道这个道理后,我对C语言指针函数中定义类型这件小事立马就一通百通了
定义的样子,和使用的时候的样孓是一样一样的
这定义了一个指向整数的指针。那么这个指针怎么变成整数呢很简单,只需要 *p 就可以了我们惊奇的发现,定义时和使用时的形式是一模一样的这不是个巧合,是语言设计者有意为之的
int *p 的意思就是让 *p 为整形。那么 p 自然是指向整数的指针了
这个p是什麼我们不知道,但我们知道 (*p)(int) 是个整数所以, *p 是个 返回整数的函数而p就是指向这种函数的指针啦。
那么如何定义函数指针的指针呢简單点说,就是加个 * 就行了
假如不幸的是,我们一开始加错了地方变成了:
我们来用我们的脑袋检验一下(你需要熟悉运算符优先级(這里又有一个口诀:小括号的运算级最高)): *(*p)(int) 是个整数,所以 (*p)(int) 是个整数的指针 所以 *p 是个函数,返回一个整数指针所以p是个函数指针。
那么我们将*挪一下地方。
再来检验一下:(**p)(int)是个整数 **p 是个函数,返回一个整数于是 *p 是个函数的指针。 p 是个函数指针的指针
有的时候,有的人(就是我小时候)会直接这样定义函数的指针的指针:
他还振振有词:这很显然呀。
我们来看看他错在哪里:
小括号的优先級最高当你写下这个语句的时候: **p(int)
实际上是先执行 p(int) 的,所以这个定义就是 **p(int) 是个整数,所以 *p(int) 就是整数的指针而p(int) 就是指针的指针,所以p僦是函数(之前这里说错了,感谢大家在评论区的指导)
更新:原来《C陷阱与缺陷》第一章讲的就是这个!