LeetCode算法题-Peak Index in a Mountain Array(Java实现)

这是悦乐书的第329次更新,第352篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第199题(顺位题号是852)。如果以下属性成立,我们将数组A称为山:

  • A.length> = 3。

  • 存在一个i(0 < i < A.length-1),使得A[0] <A[1] <... A[i-1] < A[i] > A[i + 1]> ...> A[A.length - 1]。

给定一个绝对是山的数组,返回i,使得A[0] <A[1] <... A[i-1] <A[i]> A[i + 1]> ...> A [A.length - 1]。例如:

输入:[0,1,0]

输出:1


输入:[0,2,1,0]

输出:1


注意

  • 3 <= A.length <= 10000

  • 0 <= A [i] <= 10 ^ 6

  • 如上所述,A是一座山。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

数组A是座山的意思是指,数组A中的元素大小排列像山的形状一样,由低处到山顶,再由山顶到低处,而题目要求我们找的那个i就是山顶所在位置的索引,而题目给出的条件是,数组A肯定是一座山,所以可以直接使用遍历数组元素的方式,从第一位元素开始,往后比较,小于就继续往后,直到当前元素大于它的后一个元素,表示此元素就是山顶了,直接返回该元素索引即可。

public int peakIndexInMountainArray(int[] A) {
    int n = A.length;
    for (int i=0; i<n-1; i++) {
        if (A[i] < A[i+1]) {
            continue;
        } else {
            return i;
        }
    }   
    return 0;
}


03 第二种解法

思路和上面一样,也是直接遍历数组元素,进行比较,找到山顶。

public int peakIndexInMountainArray(int[] A) {
    int index = 0;
    while (A[index] < A[index+1]) {
        index++;
    }
    return index;
}


03 第三种解法

上面两种解法的时间复杂度都是O(N),我们还可以使用二分查找法,将时间复杂度降低为O(logN)。定义两个变量left、right,一个从0开始,一个从数组最后一位开始,每次取两者中间值,得到该中间位置的元素,然后和它的前一个元素比较大小,如果小于,说明还没有到山顶,需要继续向前,将中间值加1后赋值给left,反之就将中间值赋值给right。循环结束的条件是left不小于right,最后返回left即可。

public int peakIndexInMountainArray(int[] A) {
    int left = 0, right = A.length-1;
    while (left < right) {
        int mid = left + (right-left)/2;
        if (A[mid] < A[mid+1]) {
            left = mid+1;
        } else {
            right = mid;
        }
    }
    return left;
}


04 小结

算法专题目前已日更超过五个月,算法题文章199+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • <center>#1 Two Sum</center> link Description:Given an arr...
    铛铛铛clark阅读 6,696评论 0 3
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    开心的锣鼓阅读 8,587评论 0 9
  • 贪心算法 贪心算法总是作出在当前看来最好的选择。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上...
    fredal阅读 13,068评论 3 52
  • 回溯算法 回溯法:也称为试探法,它并不考虑问题规模的大小,而是从问题的最明显的最小规模开始逐步求解出可能的答案,并...
    fredal阅读 14,704评论 0 89
  • 病符,是指旧太岁。病符所冲的就是死符,是病的极限,病极不死又能是什么呢为何不把本年太岁所冲的称为死符呢?大岁是一岁...
    华德文化传媒阅读 17,188评论 0 0

友情链接更多精彩内容