码迷,mamicode.com
首页 > 编程语言 > 详细

c语言 运用递归算法求出数组中的最大值

时间:2020-05-24 00:22:53      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:简单的   数组   max   一个   else   number   类型   递归   span   

我们很简单的把一个拥有n个数字的int类型的数组看成两个部分,

前n-1项和第n项

在进行比较大小的时候,就直接拿前n-1项和第n项进行比较:

如果第n项比较大,就return出第n项

如果前n-1项比第n项要大,就用递归的方法return出前n-1项的最大值

当然这一切都建立在传入当前函数的数字大于1的情况下,当传入的数字为1是,这个数字就为最大值

上面的那一句话就作为递归的出口使用

int MaxNumber(int number[],int n)
{
    if(n>=1)
    {
        if(MaxNumber(number, n-1)>number[n])
             return MaxNumber(number, n-1);
         else
             return number[n];
    }
    else
        return number[0];

}
int main(){
    int a[9]={9,8,7,6,5,4,3,21,2};
    int number=MaxNumber(a, 8);
    printf("%d\t",number);
}

 

c语言 运用递归算法求出数组中的最大值

标签:简单的   数组   max   一个   else   number   类型   递归   span   

原文地址:https://www.cnblogs.com/oldfish123/p/12945189.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!