leetcode 寻找峰值 Java

题干

峰值元素是指其值大于左右相邻值的元素。

给定一个输入数组 nums,其中 nums[i] ≠ nums[i+1],找到峰值元素并返回其索引。

数组可能包含多个峰值,在这种情况下,返回任何一个峰值所在位置即可。

你可以假设 nums[-1] = nums[n] = -∞。

示例 1:

输入: nums = [1,2,3,1]
输出: 2
解释: 3 是峰值元素,你的函数应该返回其索引 2

示例 2:

输入: nums = [1,2,1,3,5,6,4]
输出: 15 
解释: 你的函数可以返回索引 1,其峰值元素为 2;
     或者返回索引 5, 其峰值元素为 6

说明:

你的解法应该是 O(logN) 时间复杂度的。

想法

O(logN) 就是在诱惑我用二分法。
那就二分法呗,题比较简单,直接看代码也看得懂,不再赘述

Java 代码

class Solution {
    public int findPeakElement(int[] nums) {
        int len=nums.length;
        if(len==1){//长度为1,那么0坐标这个数一定为峰
            return 0;
        }
        if(nums[0]>nums[1]){//因为nums[-1]为无穷小,如果nums[0]比nums[1]大,也是驼峰
            return 0;
        }
        if(nums[len-1]>nums[len-2]){//因为nums[len]为无穷小,如果nums[len-1]比nums[len-2]大,也是驼峰
            return len-1;
        }
        int l=1;
        int r=len-2;
            return bisearch(nums,l,r);//二分法
        
    }
    public int bisearch(int[] nums,int l,int r){
        if(l>=r){
            return r;
        }
        int mid=(l+r)/2;
        if(nums[mid]>nums[mid-1]&&nums[mid]>nums[mid+1]){
            return mid;
        }
        if(nums[mid]<nums[mid-1]){
            return bisearch(nums,l,mid-1);
        }
        else{
            return bisearch(nums,mid+1,r);
        }
    }
}

大佬代码,直接二分法查找,简洁快速

class Solution {
    public int findPeakElement(int[] nums) {
        int low = 0;
		int high = nums.length - 1;
		while(low < high) {
			int mid1 = (low + high) / 2;
			int mid2 = mid1 + 1;
			if(nums[mid1] < nums[mid2])
				low = mid2;
			else
				high = mid1;
		}
		return low;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值