C语言代码中的二分法

#include
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    int k = 7;//计算7的下标
    int sz = sizeof(arr) / sizeof(arr[0]);//计算元素个数
    int left = 0;
    int right = sz-1;
    while (left <= right)
    {
        int mid = (left + right) / 2;
        if (arr[mid] > k)
        {
            right = mid - 1;
        }
        else if (arr[mid] < k)
        {
            left = mid - 1;
        }
        else {
            printf("找到了,下标是:%d\n", mid);
            break;
        }
    }
    if (left > right)
    {
        printf("找不到\n");
    }
    return 0;
}

你可能感兴趣的:(c语言,算法,数据结构)