找到,返回下標;
int binary_search(const int* a, int low_position, int high_position, const int key)
{
    high_position--;
    while(low_position < high_position) {
        int mid_position = (low_position+high_position) >> 1;
        if(a[mid_position] == key) return mid_position;
        else if(a[mid_position] < key) low_position = mid_position + 1;
        else high_position = mid_position - 1;
    }
    return -1;
}char* binary_search(const int* a, int low_position, int high_position, const int key)
{
    high_position--;
    char **result = {"success", "fail"};
    while(low_position < high_position) {
        int mid_position = (low_position+high_position) >> 1;
        if(a[mid_position] == key) return *result;
        else if(a[mid_position] < key) low_position = mid_position + 1;
        else high_position = mid_position - 1;
    }
    return *(result+1);
}原文:http://blog.csdn.net/keshacookie/article/details/40457643