寻找峰值

目录

​​​​​​一:题目链接

二:题目思路

三:代码实现


​​​​​​一:题目链接

二:题目思路

首先,题目会出现三种情况。

        情况1:数组元素随着下标增加一直增大,也就是 “直线往上” ,题目结果就是返回数组最后一个元素位置

        情况2:数组元素随着下标增加一直减小,也就是 “直线往下” ,题目结果就是返回数组第一个元素位置。

        情况3:数组元素大小变化不固定,也就是 “起伏不平”,此时,可以这样分析,如图:

        mid 是对应元素位置,线的高低表示当前位置元素的大小,此时可以说明 mid 左边(包括 mid)一定会有峰值。此时 mid 右边的就不用管了。同理,另一种起伏如下图:

      此时可以说明 mid 右边一定会有峰值。此时 mid 左边的就不用管了。

       到这里,我们发现了其 “二段性” ,就可以使用 二分查找 算法来解决了

三:代码实现

        int left = 0;
        int right = nums.length - 1;

        while(left < right) {
            int mid = left + (right - left) / 2;

            if(nums[mid] < nums[mid + 1]) {
                left = mid + 1;
            }else {
                right = mid;
            }
        }

        return left;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值