一个有序数组[1,2,3,3,5,6,10,19] 输出->输入数字的左边最大值 比如: 3->2 19->10 11->10
public Integer search(Integer[] nums, Integer target) { if(target<nums[0]){ return null; } int high = nums.length-1; if(target>nums[high]){ return a[high]; } int low = 0; while(low<=high){ int mid = (low+high)/2; if(target>nums[mid]){ if(target<nums[mid+1]){ return nums[mid]; }else{ low = mid+1; } }else if(target<nums[mid]){ if(target>nums[mid-1]){ return nums[mid-1]; }else{ high = mid-1; } }else{ if(a[mid-1]!=target){ return a[mid-1]; }else{ high = mid -1; } } } }
标签:10,return,左边,最大值,mid,else,high,数组,Integer From: https://www.cnblogs.com/shijianchuzhenzhi/p/16735811.html