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

一个数组先升序再降序,用最优时间复杂度,求最大值?例如[1,2,2,2,2,3,1]

一个数组先升序再降序,用最优时间复杂度,求最大值?例如[1,2,2,2,2,3,1]

C++
慕姐4208626 2018-11-14 08:25:07
一个数组先升序再降序,求最大值?例如[1,2,2,2,2,3,1],用最优时间复杂度,算法实现获取最大值3
查看完整描述

1 回答

?
心有法竹

TA贡献1866条经验 获得超5个赞

两种方案吧
第一种遍历一次,找到开始变小的那个i,a[i-1]就是最大值,复杂度O(n);
第二种,二分法,先去中间的三个值,判断这三个值是否单调,如果不是单调,中间那个就是最大值,否则根据单调方向,找到下一段数组进行二分查找。复杂度O(logn)

查看完整回答
反对 回复 2018-11-14
  • 1 回答
  • 0 关注
  • 534 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信