给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 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 |
提示:
- 1 <= nums.length <= 104
- -104 <= nums[i] <= 104
- nums 为 无重复元素 的 升序 排列数组
- -104 <= target <= 104
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/search-insert-position
此题考点:二分法查找
nums数组为无重复的升序排列的升序数组故应使用二分查找
class Solution {
public int searchInsert(int[] nums, int target) {
int left = 0, right = nums.length - 1;
//二分查找终止条件left>right
while (left <= right) {
//不使用(left+right)/2是为了防止超出int范围
int mid = left + (right - left) / 2;
if (nums[mid] == target) {
return mid;
}
//如果中间值<目标值,left右移到mid+1,否则right左移到mid-1
else if (nums[mid] < target) {
left = mid + 1;
} else {
right = mid - 1;
}
//若目标值不存在与nums数组中,则最后left指向的下标一定是应该插入的位置
}
return left;
}
}