给定一个排序数组和一个目标值,如果在数组中找到目标值则返回索引。如果没有,返回到它将会被按顺序插入的位置。
你可以假设在数组中无重复元素。
样例
[1,3,5,6],5 → 2
[1,3,5,6],2 → 1
[1,3,5,6], 7 → 4
[1,3,5,6],0 → 0
O(log(n)) time
快速查找
class Solution {
/**
* param A : an integer sorted array
* param target : an integer to be inserted
* return : an integer
*/
public:
int searchInsert(vector<int> &A, int target) {
// write your code here
if(A.empty())
return 0;
int n=A.size();
int first=0,end=n-1,mid;
while(first<end){
mid=(first+end)/2;
if(A[mid]==target)
return mid;
else if(A[mid]>target)
end=mid-1;
else
first=mid+1;
}
if(A[first]>=target)
return first;
else
return first+1;
}
};