读懂题目意思很简单,但是,注意边界条件。很容易想到二分查找。但是总是写不对,多个边界条件把我搞的一团糟。
后来,发现身来之笔。就是最后一句的
return left
简直太巧妙了 把整个代码都精简了。感觉就是想的一团乱码,最后一句话搞定。
return left配合while(left<=max)使用,使得边界时先+1/-1然后判断while,不满足后返回。
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
你可以假设数组中无重复元素。
示例 1:
输入: [1,3,5,6], 5
输出: 2
示例 2:
输入: [1,3,5,6], 2
输出: 1
示例 3:
输入: [1,3,5,6], 7
输出: 4
示例 4:
输入: [1,3,5,6], 0
输出: 0
int searchInsert(vector<int>& nums, int target) {
int size=nums.size();
if(size==0) return 0;
int left=0;
int right=size-1;
while (left <= right) {
int mid = (left + right) / 2;
if (nums[mid] == target) {
return mid;
} else if (nums[mid] < target) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return left;
}