题目:
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 O(log n) 的算法。
示例1:
输入: nums = [1,3,5,6], target = 5
输出: 2
示例2:
输入: nums = [1,3,5,6], target = 2
输出: 1
示例3:
输入: nums = [1,3,5,6], target = 7
输出: 4
示例4:
输入: nums = [1,3,5,6], target = 0
输出: 0
示例5:
输入: nums = [1], target = 0
输出: 0
提示:
1 < = n u m s . l e n g t h < = 1 0 4 1 <= nums.length <= 10^4 1<=nums.length<=104
- 1 0 4 < = n u m s [ i ] < = 1 0 4 10^4 <= nums[i] <= 10^4 104<=nums[i]<=104
nums 为无重复元素的升序排列数组
- 1 0 4 < = t a r g e t < = 1 0 4 10^4 <= target <= 10^4 104<=target<=104
解题代码:
int searchInsert(int* nums, int numsSize, int target){
int left = 0;
int right = numsSize -1;
int ans = numsSize;
while(left <= right){
int mid = (left + right) / 2;
if(target <= nums[mid]){
// 如果找到元素 ans记录的就是元素的位置 如果没找到就记录应该插入的位置
// 也就是mid的位置 最后一次二分nums[mid]就是与target值最接近的元素
ans = mid;
right = mid - 1;
}else
left = mid + 1;
}
return ans;
}