/*给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 O(log n) 的算法。*/
//在已经排序的数组中搜索,更快的就是采用二分查找,可以减少时间复杂度
int searchInsert(int* nums, int numsSize, int target)
{
int left = 0, right = numsSize - 1, ans = numsSize;
while (left <= right)
{
int mid = left + ((right - left) >> 1);
if (target <= nums[mid])
{
ans = mid;
right = mid - 1;
}
else
{
left = mid + 1;
}
}
return ans;
}
//下面的方法与上面的类似,只是更加简化,最后输出left即可,因为临界情况,最后一定有left=right+1
int searchInsert(int* nums, int numsSize, int target)
{
int left = 0, right = numsSize - 1;
while (left <= right)
{
int mid = left + ((right - left) >> 1);//采用移位,防止溢出int型
if (target <= nums[mid])
{
right = mid - 1;
}
else
{
left = mid + 1;
}
}
return left;
}
//除了二分算法,暴力解决更能被小白理解,保留解决时间复杂度大大提升
int searchInsert(int* nums, int numsSize, int target) {
int i = 0;
for (i = 0; i < numsSize; i++)
{
if (nums[i] >= target)
return i;
}
return i;
}
//暴力解决的关键类似与遍历数组,将目标值与数组值一一对比即可