我的第20个代码

利用二分法,实现在一组有序数中寻找指定数字的下标

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{

    int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
    int k = 6;
    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)
        {
            left = mid + 1;
        }
        else if (arr[mid] > k)
        {
            right = mid + 1;
        }
        else
        {
            printf("找到了,下表是%d\n", mid);
            break;
        }
        if (left > right)
        {
            printf("找不到\n");
        }
    }
    return 0;
}//实现在一组有序数中寻找指定数字的下标

猜你喜欢

转载自blog.51cto.com/15100722/2633385
今日推荐