搜索插入位置
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
class Solution {
public int searchInsert(int[] nums, int target) {
int first = 0; //记录第一个元素下标
int index = 0; //中间位置索引 初始化0
int length = nums.length; //数组长度
while(first != length){ //相等时结束循环 即为答案
index = (first + length -1) / 2; //计算中间索引
if(target > nums[index]){ //大于说明在 [index+1,length]区间
first = index + 1;
} else { //小于说明在 [first,index]区间
length = index;
}
}
//循环结束 说明 first == length 即为答案
return first;
}
}