寻找数组中第二大数


设置两个数值来表示最大数和第二大数,在循环比较赋值即可

//找给定数组中第二大的数

int get_smax(int *arr,int length)
{
    int max;
    int smax;
    if(arr[0] > arr[1])
    {
        max = arr[0];
        smax = arr[1];
    }
    else
    {
        max = arr[1];
        smax = arr[0];
    }
    for(int i = 2; i < length; i++)
    {
        if(max < arr[i])
        {
            smax = max;
            max = arr[i];            
        }
        else if((max > arr[i]) && (arr[i] > smax))
        {
            smax = arr[i];
        }
    }
    return smax;
}

测试代码:

int main()
{
    int arr[5] = {1,2,3,4,5};
    int smax = get_smax(arr,5);
    printf("smax = %d\n",smax);
    return 0;
} 

运行结果:

smax = 4


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM