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

替换最大元素问题

#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的数字就是数组中最大的呢?

正在回答

1 回答

 你可以先把“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数组中的最大元素
}


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

举报

0/150
提交
取消

替换最大元素问题

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