题目
二分查找
class Solution {public int searchInsert(int[] nums, int target) {int len=nums.length;if(nums[len-1]<target)return len;if(nums[0]>target)return 0;//找到第一个不大于它的位置,插在它后面int left=0,right=len-1;while(left<right){int mid=(left+right)/2;if(nums[mid]==target){return mid;}else if(nums[mid]>target){right=mid;}else{left=mid+1;}}return left;}
}
显然官方题解的思路更好:我们可以将两个条件合并得出最后的目标:「在一个有序数组中找第一个大于等于 targe的下标」。