为了账号安全,请及时绑定邮箱和手机立即绑定

不懂哎,那个学霸能给我解释一下啊。

#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[0] , arr2[0]  ); //将数组arr1和数组arr2的第一个元素传入函数中
    for(i=0;i<5;i++)
    {
        printf("%d ",arr1[i]);               
    }
    return 0;   
}

正在回答

1 回答

代码应该是replaceMax(arr1,arr2[0]);

arr2[0]的数值和arr1[0]比大小,结果arr2[0] < arr1[0]  所以直接arr[1] = 1,其他位置没有变化

所以最后输出的就是arr1 ,只是把arr1[1]的值替换成了arr2[0];


0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

不懂哎,那个学霸能给我解释一下啊。

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信