- 题目描述
- 题目样例
- 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)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)