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