编写一个函数,其功能是找出一维数组最大元素的位置假设数组无相同元素,在主函数输入十个整数,调用函数。
#include <stdio.h>
int fun(int a[])
{
int i,j,max=a[0];
for(i=1;i<10;i++)
if(max<a[i])
{max=a[i];j=i;}
return j;
}
int main()
{
int i,a[10];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
printf("最大元素的位置: %d",fun(a));
return 0;
}
int fun(int a[])
{
int i,j,max=a[0];
for(i=1;i<10;i++)
if(max<a[i])
{max=a[i];j=i;}
return j;
}
int main()
{
int i,a[10];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
printf("最大元素的位置: %d",fun(a));
return 0;
}
运行示例:
注意:数组元素下标从0开始,因此最大元素的位置也是从0起算的。例如本示例中最大元素的位置7,就是说是数组的第8个元素。
温馨提示:答案为网友推荐,仅供参考
第1个回答 2018-05-15
int fun(int *a, int len)
{
int pos = 0;
int i = 0;
int temp = 0;
for (i=0; i<len; i++)
{
if (temp < a[i])
{
temp = a[i];
pos = i;
}
}
return (i);
}
{
int pos = 0;
int i = 0;
int temp = 0;
for (i=0; i<len; i++)
{
if (temp < a[i])
{
temp = a[i];
pos = i;
}
}
return (i);
}