LintCode 寻找峰值

题目

你给出一个整数数组(size为n),其具有以下特点:

相邻位置的数字是不同的
A[0] < A[1] 并且 A[n - 2] > A[n - 1]
假定P是峰值的位置则满足A[P] > A[P-1]且A[P] > A[P+1],返回数组中任意一个峰值的位置。

注意事项

数组可能包含多个峰值,只需找到其中的任何一个即可

样例
给出数组[1, 2, 1, 3, 4, 5, 7, 6]返回1, 即数值 2 所在位置, 或者6, 即数值 7 所在位置.

分析

二分法搜索

代码

class Solution {
    /**
     * @param A: An integers array.
     * @return: return any of peek positions.
     */
    public int findPeak(int[] A) {
        // write your code here
        // write your code here
        int start = 1, end = A.length-2; // 1.答案在之间,2.不会出界 
        while(start + 1 <  end) {
            int mid = (start + end) / 2;
            if(A[mid] > A[mid - 1] && A[mid] > A[mid+1]) {
                return mid;
            } else if(A[mid] < A[mid + 1]) {
                start = mid;
            } else {
                end = mid;
            }
        }
        if(A[start] < A[end]) {
            return end;
        } else { 
            return start;
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,270评论 0 4
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,769评论 0 33
  • Beside my ear, you give me your promise of life Within my...
    PeterLee5880阅读 334评论 0 0
  • 1、查看当前系统中是否已经安装了mysql数据库: 2、停止mysql服务、删除之前安装的mysql 3、查找之前...
    yuanf_689a阅读 642评论 0 0
  • 算来,大学毕业已经6年了。 许多人应该都有和我一样的经历,上初中的时候盼高中,到了高中拼了命读书,是为了传说里的大...
    晚安晴天阅读 200评论 0 0