当前位置:   article > 正文

「优选算法刷题」:搜索插入位置

「优选算法刷题」:搜索插入位置

一、题目

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

请必须使用时间复杂度为 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

二、思路解析

其实题目透露的 O( logn ) ,就是在明示我们用 二分查找 了,只不过这道题多了一个插入位置的实现。

而这也是不难的,因为当找不到的时候,我们返回 left 指针的后一个位置就行了。

三、完整代码

  1. class Solution {
  2. public int searchInsert(int[] nums, int target) {
  3. int n = nums.length;
  4. int left = 0;
  5. int right = n - 1;
  6. while(left < right){
  7. int mid = left + (right - left) / 2;
  8. if(nums[mid] < target){
  9. left = mid + 1;
  10. }else{
  11. right = mid;
  12. }
  13. }
  14. if(nums[right] < target){
  15. return left + 1;
  16. }
  17. return right;
  18. }
  19. }

以上就是本篇博客的全部内容啦,如有不足之处,还请各位指出,期待能和各位一起进步!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/黑客灵魂/article/detail/831113
推荐阅读
相关标签
  

闽ICP备14008679号