【C++】递归之求数组最大值


这个比较简单,想清楚基线条件和递归条件就可以了,直接看代码(VS直接运行):

#include<iostream>
#include<vector>
using namespace std;

int arrayMax(int data[], int length);


int main()
{
    int arr[] = {0, 5, 1, 3, 9, 2, 6, 7, 8, 4};
    int length = 10;
    int result;
    result = arrayMax(arr, length);
    cout << result << endl;

    
}

int arrayMax(int data[], int len)
{
    if (len == 1)
        return data[0];
    if (len == 2)//这一步可以不加,但是加上可以减少一层调用栈的深度
        return data[0] > data[1] ? data[0] : data[1];
    else
    {
        int t = data[len - 1];//把最后一位当成基准值,比较它和其他位的大小,返回大的
        return t > arrayMax(data, len - 1) ? t : arrayMax(data, len - 1);
    }
}

 


免责声明!

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



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