思路:
目标数组为升序数组,通过while循环,在第一次循环取中间一半的索引值,比较目标值大于还是小于,若大于则往后继续二分查找,若小于则往前二分查找,while循环结束条件为找到了目标值。
例如:数组为[1,3,5,6],输入目标值为4,则应返回2.
设置2个标志值,firstIndex和lastIndex,分别表示该次循环中的二分查找的索引范围,初始值分别为0以及数组长度-1.
每次二分查找后,比较索引值和目标值大小,如果目标值大于索引值则设置索引值+1为firstIndex,如果小于则设置索引值-1为lastIndex。(之所以+1,-1是为了方便结束循环,只有firstIndex大于lastIndex才认为没有在数组中找到目标值)
如果结束循环方式为firstIndex>lastIndex,则要根据上一次循环中的索引值与目标值的大小判断目标值应该插入到哪个位置,如果目标值小于索引值,则应该插入到索引值处,如果大于则应该插入到索引值后一位处。
代码如下:
public int SearchInsert(int[] nums, int target)
{
int length= nums.Length;
int i = (length - 1) /2;
int lastIndex = length-1;
int firstIndex = 0;
while (target!= nums[i])
{
if (nums[i] < target)
{
firstIndex = i+1;
}
else
{
lastIndex = i-1;
}
if (firstIndex> lastIndex)
{
if (nums[i] > target)
{
return i;
}
else
{
return i + 1;
}
}
int offset = (lastIndex - firstIndex) / 2;
i = firstIndex + offset;
}
return i;
}