- 题目描述
- 题目样例
- Java方法:二分查找
- 思路及算法
- 代码
- 执行结果
- 复杂度
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 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 <= 10^4 -10^4 <= nums[i] <= 10^4 nums 为无重复元素的升序排列数组 -10^4 <= target <= 10^4Java方法:二分查找 思路及算法
用二分法考虑这个插入的位置 pos,它成立的条件为:nums[pos−1]
class Solution {
public int searchInsert(int[] nums, int target) {
int n = nums.length;
int left = 0, right = n - 1, ans = n;
while (left <= right) {
int mid = ((right - left) >> 1) + left;
if (target <= nums[mid]) {
ans = mid;
right = mid - 1;
} else {
left = mid + 1;
}
}
return ans;
}
}
执行结果
- 执行结果:通过
- 执行用时:0 ms, 在所有 Java 提交中击败了100.00%的用户
- 内存消耗:38 MB, 在所有 Java 提交中击败了66.96%的用户
- 时间复杂度:O(log N),其中 N 是数组中的元素数量。
- 空间复杂度:O(1)。



