题解 | #寻找峰值#
寻找峰值
https://www.nowcoder.com/practice/fcf87540c4f347bcb4cf720b5b350c76
import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param nums int整型一维数组 * @return int整型 */ public int findPeakElement (int[] nums) { // write code here if(nums.length==1){ return 0; } int left=0,right=nums.length-1; while(left<right){ int mid=(left+right)/2; if(nums[mid]>nums[mid+1]){ right=mid; }else{ left=mid+1; } } return right; // int i=0; // while(nums[i]<nums[i+1]){ // i++; // if(i==nums.length-1){ // return i; // } // } // return i; } }
核心在于如何将left和right赋值。不过,由于数组本身的性质,因此这些可以像二分法一样直接赋值。