请编写一个函数int fun(int *s,int t,int *k),用来求出数组的最大元素在数组中的下标并存放在k所指的存储单元中。
例如,输入如下整数:
876 675 896 101 301 401 980 431 451 777
则输出结果为6,980。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
试题程序:
#include <conio.h>
#include <stdio.h>
int fun(int *s,int t,int *k)
main()
int a[10]= 876,675,896,101,301,401,
980,431,451,777,k;
clrscr();
fun(a, 10, &k);
printf("%d, %d\n ", k, a[k]);
参考答案:
int fun(int *s,int t,int *k)
{
int i;
*k=0; /*k所指的数是数组的下标值*/
for(i=0;i<t;i++)
if(s[*k]<s[i]) *k=i; /*找到数组的最大元素,把该元素的下标赋给k所指的数*/
return s[*k]; /*返回数组的最大元素*/
}
解析:
本题中直接使用指针变量k,但在使用时要注意对k的指针运算,此外,一开始应让*k的值为数组中的某一下标值,即*k=0。