求数组的最大值最小值

算法数组中的最大值和最小值

方法1:遍历两次求出最大值最小值 ,时间复杂度N*2

方法2:相邻两个数分为一组比较,大的放在偶数位,小的放到奇数位,然后在偶数位上找到最大值,在奇数位上找到最小值N*1.5

方法3:定义两个变量Max,Min值,相邻两个数分为一组,比较出最大值和最小值,最大值和Max比较,是否大于Max,如果大于赋值于Max,最小值和Min比较,是否小于Min,如果小于赋值于Min

方法4:递归方法,分别求出前后N/2个数的Min和Max

 

代码:

(Max,Min)Search(arr, b, e) 

{ 
     If(e-b<=1) 
     { 

        If(arr[b]<arr[e]) 

        { 

           Return arr[e], arr[b]; 

        } 

        Else 

        { 

          Return arr[b], arr[e]; 

        } 

     } 

     MaxL,MinL=Search(arr,b,b+(e-b)/2); 

     MaxR,MinR=Search(arr,b+(e-b)/2,e); 

     If(MaxL>MaxR) 

        maxV=maxL; 

     else 

        maxV=maxR; 

     if(minL<minR) 

        minV=minL; 

     else 

     minV=minR; 

     return  maxV,minV; 

}


扩展:
 求N个数组中,第二大的数:分别求出前后N/2中的最大值,比较返回较小的那个

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值