二分查找法代码:
前提连续内存的有序数组
int binary_sort(int array[], int length, int value)
{
if(NULL == array || 0 == length)
return -1;
int start = 0;
int end = length -1;
while(start <= end){
int middle = start + ((end - start) >> 1);
if(value == array[middle])
return middle;
else if(value > array[middle]){
start = middle + 1;
}else{
end = middle -1;
}
}
return -1;
}