#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数组中的最大元素 }