CC++解OJ题——搜索插入位置(是题简单了,还是你变强了)

CC++解OJ题——搜索插入位置(是题简单了,还是你变强了),第1张


一.原题如下

  给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
  请必须使用时间复杂度为 O(log n) 的算法。


二.示例如下


三.分析
  首先最重要的一点就是数组是一个排序数组,并且是按升序排序。假设目标值target存在于数组中,如下:

  依次遍历数组,当i=2时满足目标值,返回索引值2即可。当目标值不存在于数组中时,如下:

  同样遍历数组,因为数组是按照升序进行排序的,所以当数组遍历到的数组元素大于目标值target时,即3>2,说明该目标值不存在于数组中,此时返回待插入的位置,依旧是数组索引i的值。
  所以根据分析不管找到目标值还是没有找到目标值,都返回数组索引i的值。


四.代码实现

//C实现
int searchInsert(int* nums, int numsSize, int target){
    for(int i=0;i<numsSize;i++)
    {
        if(nums[i]>=target)
        {
            return i;
        }
    }
    return numsSize;//遍历到数组最后
}
//C++实现
class Solution {
public:
    int searchInsert(vector<int>& nums, int target) {
        for(int i=0;i<nums.size();i++)
        {
            if(nums[i]>=target)
            {
                return i;
            }
        }
        return nums.size();
    }
};

我是老胡,感谢阅读!❤️ ❤️

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1354160.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-14
下一篇2022-06-14

发表评论

登录后才能评论

评论列表(0条)

    保存