给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 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 <= nums.length <= 104
-104 <= nums[i] <= 104
nums
为无重复元素的升序排列数组-104 <= target <= 104
Related Topics
- 数组
- 二分查找
提示说可以用二分,但是我没用,之后可以试一下,我的博客里分享过二分查找
算法思路:遍历数组,如果数组元素等于目标元素,就返回数组元素的下标;
如果数组元素比目标元素大时,说明目标元素应该放在该数组元素
// 搜索插入的位置,nums有就返回下标,没有就返回应该插入的位置nums有序
public static int searchInsert(int[] nums, int target) {
if(nums == null || nums.length == 0){
return 0;
}
int index = 0;
int length = nums.length;
while(target >= nums[index]){
if(nums[index] == target){
return index;
}
// 这一步++有可能会越界
index ++;
if(index == length){
break;
}
}
return index;
}