#include <stdio.h>
void replaceMax(int arr[],int value)
{
int max = arr[0];
int index = 0;
int i;
for(i=1;i<5;i++)
{
if(arr[i]>max)
{
max=arr[i]; //将数组中较大的数赋值给max
index = i; //记录当前索引
}
}
arr[index] = value;
}
int main()
{
int arr1[] = {10,41,3,12,22};
int arr2[] = {1,2,3,4,5};
int i;
replaceMax(arr1, arr2[0] ); //将数组arr1和数组arr2的第一个元素传入函数中
for(i=0;i<5;i++)
{
printf("%d ",arr1[i]);
}
return 0;
}
替换最大元素这里,arr[i]>max,max=arr[0]=10的,arr[i]中不止41一个大于10,怎么能确定第一个大于10的数字就是数组中最大的呢?
你可以先把“arr1"数组最大的元素排在第一个,下面代码可以参考一下
void sortarr(int arr,int n) //定义函数,第一个参数是数组,第二个参数为数组的长度
{
int i;
for(i=0;i<n;i++) //找出数组中最大的元素并把它排在第一位
{
if(arr[i]>=arr[0])
{
s=arr[0];
arr[0]=arr[i];
arr[i]=s;
}
}}
上面的代码直接对传入数组的内存地址进行操作,会改变原数组的顺序,如果不想改变原数组的顺序,可以参考下面的代码,我水平有限,只能帮到这了
int sortarr(int arr,int n) //定义函数,第一个参数是数组,第二个参数为数组的长度
{
int i;
int arr2[]; //重新定义一个数组来复制目标数组
for(i=0;i<n;i++) //把arr数组的元素复制到arr2数组
{
arr2[i]=arr[i];
}
for(i=0;i<n;i++) //找出arr2数组中最大的元素并把它排在第一位
{
if(arr2[i]>=arr[0])
{
s=arr2[0];
arr2[0]=arr2[i];
arr2[i]=s;
}
}
return arr2[0]; //返回值为arr2[0],即是arr数组中的最大元素
}