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


一.原题如下
在这里插入图片描述
  给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
  请必须使用时间复杂度为 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();
    }
};

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值