ybq19513345431 2024-03-29 22:17 采纳率: 28.6%
浏览 2
已结题

这个找不到的代码结果为什么不正确?

#include<stdio.h>
int TWO(int arr[], int n, int sz)
{
    int l = 0;
    int r = sz - 1;
    
    while (l <= r)
    {
    int mid = l + (r - l) / 2;
        if (arr[mid] > n)
        {
            r = mid - 1;
        }
        else if (arr[mid] < n)
        {
            l = mid + 1;
        }
        else
        {
            return mid;
        }
    }
    return -1;
}
int main()
{
    int arr[] = { 1,2,3,4,5,6,7,8,9 };
    int n = 17;
    int sz = sizeof(arr) / sizeof(arr[0]);
    int ret = TWO(arr, n, sz);
    if (TWO==-1)
    {
      printf("没找到!\n");
    }
    else
    {
        printf("找到了,下标是:%d\n", ret);;
    }

    return 0;
}
  • 写回答

3条回答 默认 最新

  • micthis 2024-03-29 22:39
    关注

    这也太粗心了,if(TWO==-1)?ret==-1

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月7日
  • 已采纳回答 3月30日
  • 创建了问题 3月29日